2008-08-12 20:20:18 +02:00
< ? php
2018-09-09 09:36:12 +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 >
2018-10-27 14:43:12 +02:00
* Copyright ( C ) 2005 - 2015 Regis Houssin < regis . houssin @ inodbox . com >
2018-09-09 09:36:12 +02:00
* Copyright ( C ) 2006 Andre Cianfarani < acianfa @ free . fr >
* Copyright ( C ) 2010 - 2015 Juanjo Menent < jmenent @ 2 byte . es >
* Copyright ( C ) 2012 - 2013 Christophe Battarel < christophe . battarel @ altairis . fr >
* Copyright ( C ) 2012 - 2013 Cédric Salvador < csalvador @ gpcsolutions . fr >
* Copyright ( C ) 2012 - 2014 Raphaël Doursenaud < rdoursenaud @ gpcsolutions . fr >
* Copyright ( C ) 2013 Jean - Francois FERRY < jfefe @ aternatik . fr >
* Copyright ( C ) 2013 - 2014 Florian Henry < florian . henry @ open - concept . pro >
* Copyright ( C ) 2013 Cédric Salvador < csalvador @ gpcsolutions . fr >
* Copyright ( C ) 2014 - 2018 Ferran Marcet < fmarcet @ 2 byte . es >
* Copyright ( C ) 2015 - 2016 Marcos García < marcosgdf @ gmail . com >
* Copyright ( C ) 2018 Frédéric France < frederic . france @ netlogic . fr >
2013-09-06 11:02:57 +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
* the Free Software Foundation ; either version 3 of the License , or
* ( 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
* along with this program . If not , see < http :// www . gnu . org / licenses />.
*/
2008-08-12 20:20:18 +02:00
/**
2017-03-20 20:58:43 +01:00
* \file htdocs / compta / facture / card . php
2014-02-23 20:10:05 +01:00
* \ingroup facture
2014-03-19 23:49:07 +01:00
* \brief Page to create / see an invoice
2013-08-06 23:50:12 +02:00
*/
2014-03-19 23:49:07 +01:00
2017-03-20 20:58:43 +01:00
require '../../main.inc.php' ;
2013-03-24 00:35:40 +01:00
require_once DOL_DOCUMENT_ROOT . '/compta/facture/class/facture.class.php' ;
2016-01-08 16:30:43 +01:00
require_once DOL_DOCUMENT_ROOT . '/compta/facture/class/facture-rec.class.php' ;
2017-10-07 21:03:46 +02:00
require_once DOL_DOCUMENT_ROOT . '/compta/bank/class/account.class.php' ;
2013-03-24 00:35:40 +01:00
require_once DOL_DOCUMENT_ROOT . '/compta/paiement/class/paiement.class.php' ;
require_once DOL_DOCUMENT_ROOT . '/core/modules/facture/modules_facture.php' ;
require_once DOL_DOCUMENT_ROOT . '/core/class/discount.class.php' ;
require_once DOL_DOCUMENT_ROOT . '/core/class/html.formfile.class.php' ;
require_once DOL_DOCUMENT_ROOT . '/core/class/html.formother.class.php' ;
2015-09-24 21:05:58 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/class/html.formmargin.class.php' ;
2013-03-24 00:35:40 +01:00
require_once DOL_DOCUMENT_ROOT . '/core/lib/invoice.lib.php' ;
2012-08-16 19:18:24 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/lib/functions2.lib.php' ;
require_once DOL_DOCUMENT_ROOT . '/core/lib/date.lib.php' ;
2013-03-24 00:35:40 +01:00
require_once DOL_DOCUMENT_ROOT . '/core/class/extrafields.class.php' ;
2014-02-23 20:10:05 +01:00
if ( ! empty ( $conf -> commande -> enabled ))
require_once DOL_DOCUMENT_ROOT . '/commande/class/commande.class.php' ;
if ( ! empty ( $conf -> projet -> enabled )) {
2013-06-14 22:33:01 +02:00
require_once DOL_DOCUMENT_ROOT . '/projet/class/project.class.php' ;
2014-02-23 20:10:05 +01:00
require_once DOL_DOCUMENT_ROOT . '/core/class/html.formprojet.class.php' ;
2013-06-14 22:33:01 +02:00
}
2014-02-23 20:10:05 +01:00
require_once DOL_DOCUMENT_ROOT . '/core/class/doleditor.class.php' ;
2008-08-12 20:20:18 +02:00
2017-02-08 12:37:38 +01:00
if ( ! empty ( $conf -> variants -> enabled )) {
require_once DOL_DOCUMENT_ROOT . '/variants/class/ProductCombination.class.php' ;
2016-07-23 16:37:21 +02:00
}
2017-05-14 21:20:35 +02:00
if ( ! empty ( $conf -> accounting -> enabled )) {
require_once DOL_DOCUMENT_ROOT . '/accountancy/class/accountingjournal.class.php' ;
}
2016-07-23 16:37:21 +02:00
2018-05-27 09:27:09 +02:00
// Load translation files required by the page
2018-01-04 14:35:02 +01:00
$langs -> loadLangs ( array ( 'bills' , 'companies' , 'compta' , 'products' , 'banks' , 'main' , 'withdrawals' ));
2017-12-10 15:24:47 +01:00
if ( ! empty ( $conf -> incoterm -> enabled )) $langs -> load ( 'incoterm' );
if ( ! empty ( $conf -> margin -> enabled )) $langs -> load ( 'margins' );
2014-02-23 20:10:05 +01:00
2017-09-02 12:36:22 +02:00
$projectid = ( GETPOST ( 'projectid' , 'int' ) ? GETPOST ( 'projectid' , 'int' ) : 0 );
2014-02-23 20:10:05 +01:00
$id = ( GETPOST ( 'id' , 'int' ) ? GETPOST ( 'id' , 'int' ) : GETPOST ( 'facid' , 'int' )); // For backward compatibility
$ref = GETPOST ( 'ref' , 'alpha' );
$socid = GETPOST ( 'socid' , 'int' );
$action = GETPOST ( 'action' , 'alpha' );
$confirm = GETPOST ( 'confirm' , 'alpha' );
2016-02-16 22:26:23 +01:00
$cancel = GETPOST ( 'cancel' , 'alpha' );
2014-02-23 20:10:05 +01:00
$lineid = GETPOST ( 'lineid' , 'int' );
$userid = GETPOST ( 'userid' , 'int' );
2017-09-02 12:36:22 +02:00
$search_ref = GETPOST ( 'sf_ref' , 'alpha' ) ? GETPOST ( 'sf_ref' , 'alpha' ) : GETPOST ( 'search_ref' , 'alpha' );
2014-02-23 20:10:05 +01:00
$search_societe = GETPOST ( 'search_societe' , 'alpha' );
$search_montant_ht = GETPOST ( 'search_montant_ht' , 'alpha' );
$search_montant_ttc = GETPOST ( 'search_montant_ttc' , 'alpha' );
$origin = GETPOST ( 'origin' , 'alpha' );
$originid = ( GETPOST ( 'originid' , 'int' ) ? GETPOST ( 'originid' , 'int' ) : GETPOST ( 'origin_id' , 'int' )); // For backward compatibility
2016-04-27 10:56:40 +02:00
$fac_rec = GETPOST ( 'fac_rec' , 'int' );
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
// PDF
$hidedetails = ( GETPOST ( 'hidedetails' , 'int' ) ? GETPOST ( 'hidedetails' , 'int' ) : ( ! empty ( $conf -> global -> MAIN_GENERATE_DOCUMENTS_HIDE_DETAILS ) ? 1 : 0 ));
$hidedesc = ( GETPOST ( 'hidedesc' , 'int' ) ? GETPOST ( 'hidedesc' , 'int' ) : ( ! empty ( $conf -> global -> MAIN_GENERATE_DOCUMENTS_HIDE_DESC ) ? 1 : 0 ));
$hideref = ( GETPOST ( 'hideref' , 'int' ) ? GETPOST ( 'hideref' , 'int' ) : ( ! empty ( $conf -> global -> MAIN_GENERATE_DOCUMENTS_HIDE_REF ) ? 1 : 0 ));
2012-05-21 17:12:57 +02:00
2009-11-28 13:06:11 +01:00
// Nombre de ligne pour choix de produit/service predefinis
2014-02-23 20:10:05 +01:00
$NBLINES = 4 ;
2008-08-12 20:20:18 +02:00
2014-02-23 20:10:05 +01:00
$usehm = ( ! empty ( $conf -> global -> MAIN_USE_HOURMIN_IN_DATE_RANGE ) ? $conf -> global -> MAIN_USE_HOURMIN_IN_DATE_RANGE : 0 );
2008-10-02 00:24:31 +02:00
2014-02-23 20:10:05 +01:00
$object = new Facture ( $db );
2013-03-06 04:17:14 +01:00
$extrafields = new ExtraFields ( $db );
2008-08-12 20:20:18 +02:00
2012-07-02 19:30:37 +02:00
// Load object
2014-02-23 20:10:05 +01:00
if ( $id > 0 || ! empty ( $ref )) {
2016-01-13 13:42:58 +01:00
$ret = $object -> fetch ( $id , $ref , '' , '' , $conf -> global -> INVOICE_USE_SITUATION );
2012-05-10 19:26:44 +02:00
}
2017-06-10 12:56:28 +02:00
// Initialize technical object to manage hooks of page. Note that conf->hooks_modules contains array of hook context
2014-10-06 07:20:58 +02:00
$hookmanager -> initHooks ( array ( 'invoicecard' , 'globalcard' ));
2010-09-12 20:01:29 +02:00
2018-11-14 14:59:36 +01:00
$usercanread = $user -> rights -> facture -> lire ;
$usercancreate = $user -> rights -> facture -> creer ;
$usercanissuepayment = $user -> rights -> facture -> paiement ;
$usercandelete = $user -> rights -> facture -> supprimer ;
$usercanvalidate = (( empty ( $conf -> global -> MAIN_USE_ADVANCED_PERMS ) && $usercancreate ) || ( ! empty ( $conf -> global -> MAIN_USE_ADVANCED_PERMS ) && ! empty ( $user -> rights -> facture -> invoice_advance -> validate )));
$usercansend = ( empty ( $conf -> global -> MAIN_USE_ADVANCED_PERMS ) || $user -> rights -> facture -> invoice_advance -> send );
$usercanreopen = ( empty ( $conf -> global -> MAIN_USE_ADVANCED_PERMS ) || $user -> rights -> facture -> invoice_advance -> reopen );
$usercanunvalidate = (( empty ( $conf -> global -> MAIN_USE_ADVANCED_PERMS ) && ! empty ( $usercancreate )) || ( ! empty ( $conf -> global -> MAIN_USE_ADVANCED_PERMS ) && ! empty ( $user -> rights -> facture -> invoice_advance -> unvalidate )));
$usercanproductignorepricemin = (( ! empty ( $conf -> global -> MAIN_USE_ADVANCED_PERMS ) && empty ( $user -> rights -> produit -> ignore_price_min_advance )) || empty ( $conf -> global -> MAIN_USE_ADVANCED_PERMS ));
$usercancreatemargin = $user -> rights -> margins -> creer ;
$usercanreadallmargin = $user -> rights -> margins -> liretous ;
$usercancreatewithdrarequest = $user -> rights -> prelevement -> bons -> creer ;
$permissionnote = $usercancreate ; // Used by the include of actions_setnotes.inc.php
$permissiondellink = $usercancreate ; // Used by the include of actions_dellink.inc.php
$permissiontoedit = $usercancreate ; // Used by the include of actions_lineupdonw.inc.php
2010-09-12 20:01:29 +02:00
2018-10-29 18:19:40 +01:00
// Security check
2018-12-02 14:31:45 +01:00
$fieldid = ( ! empty ( $ref ) ? 'ref' : 'rowid' );
2018-10-29 18:19:40 +01:00
if ( $user -> societe_id ) $socid = $user -> societe_id ;
2018-10-29 18:28:19 +01:00
$isdraft = (( $object -> statut == Facture :: STATUS_DRAFT ) ? 1 : 0 );
2018-10-30 14:47:39 +01:00
$result = restrictedArea ( $user , 'facture' , $id , '' , '' , 'fk_soc' , $fieldid , $isdraft );
2018-10-29 18:19:40 +01:00
2011-10-01 21:55:40 +02:00
/*
* Actions
*/
2008-08-12 20:20:18 +02:00
2014-02-23 20:10:05 +01:00
$parameters = array ( 'socid' => $socid );
$reshook = $hookmanager -> executeHooks ( 'doActions' , $parameters , $object , $action ); // Note that $action and $object may have been modified by some hooks
2014-09-28 03:41:32 +02:00
if ( $reshook < 0 ) setEventMessages ( $hookmanager -> error , $hookmanager -> errors , 'errors' );
2012-05-04 18:30:35 +02:00
2015-01-18 17:13:42 +01:00
if ( empty ( $reshook ))
{
2017-09-17 15:38:50 +02:00
if ( $cancel )
{
if ( ! empty ( $backtopage ))
{
header ( " Location: " . $backtopage );
exit ;
}
$action = '' ;
}
2016-04-24 18:55:19 +02:00
include DOL_DOCUMENT_ROOT . '/core/actions_setnotes.inc.php' ; // Must be include, not include_once
2015-07-28 14:13:16 +02:00
include DOL_DOCUMENT_ROOT . '/core/actions_dellink.inc.php' ; // Must be include, not include_once
include DOL_DOCUMENT_ROOT . '/core/actions_lineupdown.inc.php' ; // Must be include, not include_once
2015-01-17 19:28:27 +01:00
// Action clone object
2018-11-14 14:59:36 +01:00
if ( $action == 'confirm_clone' && $confirm == 'yes' && $usercancreate ) {
2015-01-18 17:13:42 +01:00
// if (1 == 0 && empty($_REQUEST["clone_content"]) && empty($_REQUEST["clone_receivers"])) {
// $mesgs [] = '<div class="error">' . $langs->trans("NoCloneOptionsSpecified") . '</div>';
// } else {
2015-01-17 19:28:27 +01:00
if ( $object -> fetch ( $id ) > 0 ) {
$result = $object -> createFromClone ( $socid );
if ( $result > 0 ) {
header ( " Location: " . $_SERVER [ 'PHP_SELF' ] . '?facid=' . $result );
exit ();
} else {
2015-11-15 07:47:35 +01:00
setEventMessages ( $object -> error , $object -> errors , 'errors' );
2015-01-17 19:28:27 +01:00
$action = '' ;
}
}
2015-01-18 17:13:42 +01:00
// }
2015-01-17 19:28:27 +01:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Change status of invoice
2018-11-14 14:59:36 +01:00
else if ( $action == 'reopen' && $usercancreate ) {
2015-01-17 19:28:27 +01:00
$result = $object -> fetch ( $id );
2016-07-05 18:36:10 +02:00
if ( $object -> statut == 2 || ( $object -> statut == 3 && $object -> close_code != 'replaced' ) || ( $object -> statut == 1 && $object -> paye == 1 )) { // ($object->statut == 1 && $object->paye == 1) should not happened but can be found when data are corrupted
2015-01-17 19:28:27 +01:00
$result = $object -> set_unpaid ( $user );
2014-02-23 20:10:05 +01:00
if ( $result > 0 ) {
2015-01-17 19:28:27 +01:00
header ( 'Location: ' . $_SERVER [ " PHP_SELF " ] . '?facid=' . $id );
2014-02-23 20:10:05 +01:00
exit ();
} else {
2015-11-15 07:47:35 +01:00
setEventMessages ( $object -> error , $object -> errors , 'errors' );
2013-04-20 00:10:20 +02:00
}
}
}
2008-11-20 22:30:23 +01:00
2015-01-17 19:28:27 +01:00
// Delete invoice
2018-10-29 14:56:00 +01:00
else if ( $action == 'confirm_delete' && $confirm == 'yes' ) {
2015-01-17 19:28:27 +01:00
$result = $object -> fetch ( $id );
$object -> fetch_thirdparty ();
$idwarehouse = GETPOST ( 'idwarehouse' );
2008-11-20 22:30:23 +01:00
2015-01-17 19:28:27 +01:00
$qualified_for_stock_change = 0 ;
if ( empty ( $conf -> global -> STOCK_SUPPORTS_SERVICES )) {
$qualified_for_stock_change = $object -> hasProductsOrServices ( 2 );
} else {
$qualified_for_stock_change = $object -> hasProductsOrServices ( 1 );
}
2008-11-20 22:30:23 +01:00
2018-10-29 14:56:00 +01:00
$isErasable = $object -> is_erasable ();
2018-11-14 14:59:36 +01:00
if (( $usercandelete && $isErasable > 0 )
|| ( $usercancreate && $isErasable == 1 ))
2018-05-25 13:14:58 +02:00
{
2018-05-18 15:20:16 +02:00
$result = $object -> delete ( $user , 0 , $idwarehouse );
if ( $result > 0 ) {
2018-05-25 13:14:58 +02:00
header ( 'Location: ' . DOL_URL_ROOT . '/compta/facture/list.php?restore_lastsearch_values=1' );
2018-05-18 15:20:16 +02:00
exit ();
} else {
setEventMessages ( $object -> error , $object -> errors , 'errors' );
$action = '' ;
}
2013-04-20 00:10:20 +02:00
}
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Delete line
2018-11-14 14:59:36 +01:00
else if ( $action == 'confirm_deleteline' && $confirm == 'yes' && $usercancreate )
2015-01-18 17:13:42 +01:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
$object -> fetch_thirdparty ();
2014-03-01 19:45:13 +01:00
2015-01-18 17:13:42 +01:00
$result = $object -> deleteline ( GETPOST ( 'lineid' ));
2015-01-17 19:28:27 +01:00
if ( $result > 0 ) {
// Define output language
$outputlangs = $langs ;
$newlang = '' ;
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang ) && ! empty ( $_REQUEST [ 'lang_id' ]))
$newlang = $_REQUEST [ 'lang_id' ];
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang ))
2015-01-18 17:13:42 +01:00
$newlang = $object -> thirdparty -> default_lang ;
2015-01-17 19:28:27 +01:00
if ( ! empty ( $newlang )) {
$outputlangs = new Translate ( " " , $conf );
$outputlangs -> setDefaultLang ( $newlang );
2018-02-08 12:53:26 +01:00
$outputlangs -> load ( 'products' );
2015-01-17 19:28:27 +01:00
}
if ( empty ( $conf -> global -> MAIN_DISABLE_PDF_AUTOUPDATE )) {
$ret = $object -> fetch ( $id ); // Reload to get new records
2015-01-18 17:13:42 +01:00
$result = $object -> generateDocument ( $object -> modelpdf , $outputlangs , $hidedetails , $hidedesc , $hideref );
2015-01-17 19:28:27 +01:00
}
if ( $result >= 0 ) {
header ( 'Location: ' . $_SERVER [ " PHP_SELF " ] . '?facid=' . $id );
exit ();
}
} else {
2015-11-15 07:47:35 +01:00
setEventMessages ( $object -> error , $object -> errors , 'errors' );
2015-01-17 19:28:27 +01:00
$action = '' ;
}
2014-02-23 20:10:05 +01:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Delete link of credit note to invoice
2018-11-14 14:59:36 +01:00
else if ( $action == 'unlinkdiscount' && $usercancreate )
2015-01-18 17:13:42 +01:00
{
2015-01-17 19:28:27 +01:00
$discount = new DiscountAbsolute ( $db );
2015-01-18 17:13:42 +01:00
$result = $discount -> fetch ( GETPOST ( " discountid " ));
2015-01-17 19:28:27 +01:00
$discount -> unlink_invoice ();
2014-02-23 20:10:05 +01:00
}
2008-08-12 20:20:18 +02:00
2015-01-17 19:28:27 +01:00
// Validation
2018-11-14 14:59:36 +01:00
else if ( $action == 'valid' && $usercancreate )
2015-01-18 17:13:42 +01:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// On verifie signe facture
if ( $object -> type == Facture :: TYPE_CREDIT_NOTE ) {
// Si avoir, le signe doit etre negatif
if ( $object -> total_ht >= 0 ) {
2015-11-15 07:47:35 +01:00
setEventMessages ( $langs -> trans ( " ErrorInvoiceAvoirMustBeNegative " ), null , 'errors' );
2015-01-17 19:28:27 +01:00
$action = '' ;
}
} else {
// Si non avoir, le signe doit etre positif
if ( empty ( $conf -> global -> FACTURE_ENABLE_NEGATIVE ) && $object -> total_ht < 0 ) {
2015-11-15 07:47:35 +01:00
setEventMessages ( $langs -> trans ( " ErrorInvoiceOfThisTypeMustBePositive " ), null , 'errors' );
2015-01-17 19:28:27 +01:00
$action = '' ;
}
2012-05-06 02:27:09 +02:00
}
}
2008-08-12 20:20:18 +02:00
2018-11-14 14:59:36 +01:00
else if ( $action == 'set_thirdparty' && $usercancreate )
2015-01-18 17:13:42 +01:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
2016-09-12 20:16:39 +02:00
$object -> setValueFrom ( 'fk_soc' , $socid , '' , null , 'int' , '' , $user , 'BILL_MODIFY' );
2008-08-12 20:20:18 +02:00
2015-01-17 19:28:27 +01:00
header ( 'Location: ' . $_SERVER [ " PHP_SELF " ] . '?facid=' . $id );
exit ();
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2018-11-14 14:59:36 +01:00
else if ( $action == 'classin' && $usercancreate )
2015-01-18 17:13:42 +01:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
$object -> setProject ( $_POST [ 'projectid' ]);
2013-04-20 00:10:20 +02:00
}
2008-08-12 20:20:18 +02:00
2018-11-14 14:59:36 +01:00
else if ( $action == 'setmode' && $usercancreate )
2015-01-18 17:13:42 +01:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
$result = $object -> setPaymentMethods ( GETPOST ( 'mode_reglement_id' , 'int' ));
if ( $result < 0 )
dol_print_error ( $db , $object -> error );
}
2014-03-01 19:45:13 +01:00
2016-01-23 16:01:55 +01:00
// Multicurrency Code
2018-11-14 14:59:36 +01:00
else if ( $action == 'setmulticurrencycode' && $usercancreate ) {
2016-01-23 16:01:55 +01:00
$result = $object -> setMulticurrencyCode ( GETPOST ( 'multicurrency_code' , 'alpha' ));
}
// Multicurrency rate
2018-11-14 14:59:36 +01:00
else if ( $action == 'setmulticurrencyrate' && $usercancreate ) {
2016-12-10 22:07:25 +01:00
$result = $object -> setMulticurrencyRate ( price2num ( GETPOST ( 'multicurrency_tx' )), GETPOST ( 'calculation_mode' , 'int' ));
2016-01-23 16:01:55 +01:00
}
2016-08-10 09:47:25 +02:00
2018-11-14 14:59:36 +01:00
else if ( $action == 'setinvoicedate' && $usercancreate )
2014-08-14 08:41:24 +02:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
$old_date_lim_reglement = $object -> date_lim_reglement ;
$date = dol_mktime ( 12 , 0 , 0 , $_POST [ 'invoicedatemonth' ], $_POST [ 'invoicedateday' ], $_POST [ 'invoicedateyear' ]);
if ( empty ( $date ))
{
2017-10-16 08:47:05 +02:00
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " Date " )), null , 'errors' );
header ( 'Location: ' . $_SERVER [ " PHP_SELF " ] . '?facid=' . $id . '&action=editinvoicedate' );
exit ;
2015-01-17 19:28:27 +01:00
}
2017-10-16 08:47:05 +02:00
$object -> date = $date ;
2015-01-17 19:28:27 +01:00
$new_date_lim_reglement = $object -> calculate_date_lim_reglement ();
if ( $new_date_lim_reglement > $old_date_lim_reglement ) $object -> date_lim_reglement = $new_date_lim_reglement ;
if ( $object -> date_lim_reglement < $object -> date ) $object -> date_lim_reglement = $object -> date ;
$result = $object -> update ( $user );
if ( $result < 0 ) dol_print_error ( $db , $object -> error );
2014-09-02 12:57:33 +02:00
}
2011-06-29 17:48:02 +02:00
2018-11-14 14:59:36 +01:00
else if ( $action == 'setdate_pointoftax' && $usercancreate )
2016-05-29 23:56:58 +02:00
{
$object -> fetch ( $id );
$date_pointoftax = dol_mktime ( 12 , 0 , 0 , $_POST [ 'date_pointoftaxmonth' ], $_POST [ 'date_pointoftaxday' ], $_POST [ 'date_pointoftaxyear' ]);
2017-10-16 08:47:05 +02:00
$object -> date_pointoftax = $date_pointoftax ;
2016-05-29 23:56:58 +02:00
$result = $object -> update ( $user );
if ( $result < 0 ) dol_print_error ( $db , $object -> error );
}
2016-08-10 09:47:25 +02:00
2018-11-14 14:59:36 +01:00
else if ( $action == 'setconditions' && $usercancreate )
2014-08-14 08:41:24 +02:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
$object -> cond_reglement_code = 0 ; // To clean property
$object -> cond_reglement_id = 0 ; // To clean property
$result = $object -> setPaymentTerms ( GETPOST ( 'cond_reglement_id' , 'int' ));
if ( $result < 0 ) dol_print_error ( $db , $object -> error );
2008-08-12 20:20:18 +02:00
2015-01-17 19:28:27 +01:00
$old_date_lim_reglement = $object -> date_lim_reglement ;
$new_date_lim_reglement = $object -> calculate_date_lim_reglement ();
if ( $new_date_lim_reglement > $old_date_lim_reglement ) $object -> date_lim_reglement = $new_date_lim_reglement ;
if ( $object -> date_lim_reglement < $object -> date ) $object -> date_lim_reglement = $object -> date ;
$result = $object -> update ( $user );
if ( $result < 0 ) dol_print_error ( $db , $object -> error );
2014-09-02 12:57:33 +02:00
}
2014-03-20 00:05:20 +01:00
2018-11-14 14:59:36 +01:00
else if ( $action == 'setpaymentterm' && $usercancreate )
2014-08-14 08:41:24 +02:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
$object -> date_lim_reglement = dol_mktime ( 12 , 0 , 0 , $_POST [ 'paymenttermmonth' ], $_POST [ 'paymenttermday' ], $_POST [ 'paymenttermyear' ]);
if ( $object -> date_lim_reglement < $object -> date ) {
$object -> date_lim_reglement = $object -> calculate_date_lim_reglement ();
2015-11-15 07:47:35 +01:00
setEventMessages ( $langs -> trans ( " DatePaymentTermCantBeLowerThanObjectDate " ), null , 'warnings' );
2015-01-17 19:28:27 +01:00
}
$result = $object -> update ( $user );
if ( $result < 0 )
dol_print_error ( $db , $object -> error );
2013-04-20 00:10:20 +02:00
}
2014-03-20 00:05:20 +01:00
2018-11-14 14:59:36 +01:00
else if ( $action == 'setrevenuestamp' && $usercancreate )
2015-01-18 17:13:42 +01:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
$object -> revenuestamp = GETPOST ( 'revenuestamp' );
$result = $object -> update ( $user );
$object -> update_price ( 1 );
if ( $result < 0 )
dol_print_error ( $db , $object -> error );
2013-04-20 00:10:20 +02:00
}
2014-03-20 00:05:20 +01:00
2015-02-23 09:16:14 +01:00
// Set incoterm
elseif ( $action == 'set_incoterms' && ! empty ( $conf -> incoterm -> enabled ))
2017-10-16 08:47:05 +02:00
{
$result = $object -> setIncoterms ( GETPOST ( 'incoterm_id' , 'int' ), GETPOST ( 'location_incoterms' , 'alpha' ));
}
2015-03-18 14:31:37 +01:00
2015-01-18 17:13:42 +01:00
// bank account
2018-11-14 14:59:36 +01:00
else if ( $action == 'setbankaccount' && $usercancreate )
2015-01-18 17:13:42 +01:00
{
2017-10-16 08:47:05 +02:00
$result = $object -> setBankAccount ( GETPOST ( 'fk_account' , 'int' ));
2015-01-18 17:13:42 +01:00
}
2014-03-20 00:05:20 +01:00
2018-11-14 14:59:36 +01:00
else if ( $action == 'setremisepercent' && $usercancreate )
2015-01-18 17:13:42 +01:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
$result = $object -> set_remise ( $user , $_POST [ 'remise_percent' ]);
}
2014-07-07 17:59:04 +02:00
2018-11-14 14:59:36 +01:00
else if ( $action == " setabsolutediscount " && $usercancreate )
2015-01-18 17:13:42 +01:00
{
2017-09-19 00:24:52 +02:00
// POST[remise_id] or POST[remise_id_for_payment]
// We use the credit to reduce amount of invoice
2015-01-17 19:28:27 +01:00
if ( ! empty ( $_POST [ " remise_id " ])) {
$ret = $object -> fetch ( $id );
if ( $ret > 0 ) {
$result = $object -> insert_discount ( $_POST [ " remise_id " ]);
if ( $result < 0 ) {
2015-11-15 07:47:35 +01:00
setEventMessages ( $object -> error , $object -> errors , 'errors' );
2015-01-17 19:28:27 +01:00
}
} else {
dol_print_error ( $db , $object -> error );
2013-04-20 00:10:20 +02:00
}
}
2017-09-19 00:24:52 +02:00
// We use the credit to reduce remain to pay
if ( ! empty ( $_POST [ " remise_id_for_payment " ]))
{
2015-01-17 19:28:27 +01:00
require_once DOL_DOCUMENT_ROOT . '/core/class/discount.class.php' ;
$discount = new DiscountAbsolute ( $db );
$discount -> fetch ( $_POST [ " remise_id_for_payment " ]);
2014-03-20 00:05:20 +01:00
2017-09-19 00:24:52 +02:00
//var_dump($object->getRemainToPay(0));
//var_dump($discount->amount_ttc);exit;
2018-06-05 11:33:58 +02:00
if ( price2num ( $discount -> amount_ttc ) > price2num ( $object -> getRemainToPay ( 0 )))
2017-09-19 00:24:52 +02:00
{
// TODO Split the discount in 2 automatically
$error ++ ;
setEventMessages ( $langs -> trans ( " ErrorDiscountLargerThanRemainToPaySplitItBefore " ), null , 'errors' );
}
if ( ! $error )
{
$result = $discount -> link_to_invoice ( 0 , $id );
if ( $result < 0 ) {
setEventMessages ( $discount -> error , $discount -> errors , 'errors' );
}
2013-04-20 00:10:20 +02:00
}
}
2017-07-25 12:20:51 +02:00
if ( empty ( $conf -> global -> MAIN_DISABLE_PDF_AUTOUPDATE ))
{
$outputlangs = $langs ;
$newlang = '' ;
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang ) && GETPOST ( 'lang_id' , 'aZ09' )) $newlang = GETPOST ( 'lang_id' , 'aZ09' );
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang )) $newlang = $object -> thirdparty -> default_lang ;
if ( ! empty ( $newlang )) {
$outputlangs = new Translate ( " " , $conf );
$outputlangs -> setDefaultLang ( $newlang );
}
$ret = $object -> fetch ( $id ); // Reload to get new records
$result = $object -> generateDocument ( $object -> modelpdf , $outputlangs , $hidedetails , $hidedesc , $hideref );
if ( $result < 0 ) setEventMessages ( $object -> error , $object -> errors , 'errors' );
}
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2018-11-14 14:59:36 +01:00
else if ( $action == 'setref_client' && $usercancreate )
2015-01-18 17:13:42 +01:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
2016-09-21 01:25:34 +02:00
$object -> set_ref_client ( GETPOST ( 'ref_client' ));
2013-04-20 00:10:20 +02:00
}
2008-08-12 20:20:18 +02:00
2015-01-17 19:28:27 +01:00
// Classify to validated
2018-11-14 14:59:36 +01:00
else if ( $action == 'confirm_valid' && $confirm == 'yes' && $usercanvalidate )
2015-01-17 19:28:27 +01:00
{
2017-09-02 12:36:22 +02:00
$idwarehouse = GETPOST ( 'idwarehouse' , 'int' );
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
$object -> fetch_thirdparty ();
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Check parameters
2014-03-01 19:45:13 +01:00
2017-10-16 08:47:05 +02:00
// Check for mandatory fields defined into setup
2017-09-02 12:36:22 +02:00
$array_to_check = array ( 'IDPROF1' , 'IDPROF2' , 'IDPROF3' , 'IDPROF4' , 'IDPROF5' , 'IDPROF6' , 'EMAIL' );
foreach ( $array_to_check as $key )
2014-09-19 14:57:31 +02:00
{
2017-09-02 12:36:22 +02:00
$keymin = strtolower ( $key );
$i = ( int ) preg_replace ( '/[^0-9]/' , '' , $key );
$vallabel = $object -> thirdparty -> $keymin ;
if ( $i > 0 )
{
if ( $object -> thirdparty -> isACompany ())
{
// Check for mandatory prof id (but only if country is other than ours)
if ( $mysoc -> country_id > 0 && $object -> thirdparty -> country_id == $mysoc -> country_id )
{
$idprof_mandatory = 'SOCIETE_' . $key . '_INVOICE_MANDATORY' ;
if ( ! $vallabel && ! empty ( $conf -> global -> $idprof_mandatory ))
{
$langs -> load ( " errors " );
$error ++ ;
setEventMessages ( $langs -> trans ( 'ErrorProdIdIsMandatory' , $langs -> transcountry ( 'ProfId' . $i , $object -> thirdparty -> country_code )) . ' (' . $langs -> trans ( " ForbiddenBySetupRules " ) . ')' , null , 'errors' );
}
}
}
}
else
{
//var_dump($conf->global->SOCIETE_EMAIL_MANDATORY);
if ( $key == 'EMAIL' )
{
// Check for mandatory
if ( ! empty ( $conf -> global -> SOCIETE_EMAIL_INVOICE_MANDATORY ) && ! isValidEMail ( $object -> thirdparty -> email ))
{
$langs -> load ( " errors " );
$error ++ ;
setEventMessages ( $langs -> trans ( " ErrorBadEMail " , $object -> thirdparty -> email ) . ' (' . $langs -> trans ( " ForbiddenBySetupRules " ) . ')' , null , 'errors' );
}
}
}
2014-02-23 20:10:05 +01:00
}
2016-07-19 07:46:27 +02:00
2015-01-17 19:28:27 +01:00
$qualified_for_stock_change = 0 ;
if ( empty ( $conf -> global -> STOCK_SUPPORTS_SERVICES )) {
$qualified_for_stock_change = $object -> hasProductsOrServices ( 2 );
} else {
$qualified_for_stock_change = $object -> hasProductsOrServices ( 1 );
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Check for warehouse
2015-01-18 17:13:42 +01:00
if ( $object -> type != Facture :: TYPE_DEPOSIT && ! empty ( $conf -> global -> STOCK_CALCULATE_ON_BILL ) && $qualified_for_stock_change )
{
2015-01-17 19:28:27 +01:00
if ( ! $idwarehouse || $idwarehouse == - 1 ) {
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-11-18 16:05:41 +01:00
setEventMessages ( $langs -> trans ( 'ErrorFieldRequired' , $langs -> transnoentitiesnoconv ( " Warehouse " )), null , 'errors' );
2015-01-17 19:28:27 +01:00
$action = '' ;
}
2014-02-23 20:10:05 +01:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
if ( ! $error )
2014-03-25 20:09:30 +01:00
{
2015-01-17 19:28:27 +01:00
$result = $object -> validate ( $user , '' , $idwarehouse );
if ( $result >= 0 )
2014-10-27 19:37:30 +01:00
{
2015-01-17 19:28:27 +01:00
// Define output language
2015-01-18 17:13:42 +01:00
if ( empty ( $conf -> global -> MAIN_DISABLE_PDF_AUTOUPDATE ))
{
$outputlangs = $langs ;
$newlang = '' ;
2017-06-27 17:27:01 +02:00
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang ) && GETPOST ( 'lang_id' , 'aZ09' )) $newlang = GETPOST ( 'lang_id' , 'aZ09' );
2015-01-18 17:13:42 +01:00
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang )) $newlang = $object -> thirdparty -> default_lang ;
if ( ! empty ( $newlang )) {
$outputlangs = new Translate ( " " , $conf );
$outputlangs -> setDefaultLang ( $newlang );
2018-02-08 12:53:26 +01:00
$outputlangs -> load ( 'products' );
2015-01-18 17:13:42 +01:00
}
$model = $object -> modelpdf ;
2015-01-17 19:28:27 +01:00
$ret = $object -> fetch ( $id ); // Reload to get new records
2014-12-25 23:08:07 +01:00
2015-01-18 17:13:42 +01:00
$result = $object -> generateDocument ( $model , $outputlangs , $hidedetails , $hidedesc , $hideref );
2017-10-16 08:47:05 +02:00
if ( $result < 0 ) setEventMessages ( $object -> error , $object -> errors , 'errors' );
2015-01-17 19:28:27 +01:00
}
2015-01-18 17:13:42 +01:00
}
else
{
2015-11-18 16:05:41 +01:00
if ( count ( $object -> errors )) setEventMessages ( null , $object -> errors , 'errors' );
2015-11-15 07:47:35 +01:00
else setEventMessages ( $object -> error , $object -> errors , 'errors' );
2013-04-20 00:10:20 +02:00
}
2014-10-27 19:37:30 +01:00
}
2014-02-23 20:10:05 +01:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Go back to draft status (unvalidate)
2018-11-14 14:59:36 +01:00
else if ( $action == 'confirm_modif' && $usercanunvalidate )
2014-09-19 14:57:31 +02:00
{
2018-03-12 12:27:40 +01:00
$idwarehouse = GETPOST ( 'idwarehouse' , 'int' );
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
$object -> fetch_thirdparty ();
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$qualified_for_stock_change = 0 ;
if ( empty ( $conf -> global -> STOCK_SUPPORTS_SERVICES )) {
$qualified_for_stock_change = $object -> hasProductsOrServices ( 2 );
2014-02-23 20:10:05 +01:00
} else {
2015-01-17 19:28:27 +01:00
$qualified_for_stock_change = $object -> hasProductsOrServices ( 1 );
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Check parameters
2015-01-18 17:13:42 +01:00
if ( $object -> type != Facture :: TYPE_DEPOSIT && ! empty ( $conf -> global -> STOCK_CALCULATE_ON_BILL ) && $qualified_for_stock_change )
{
2015-01-17 19:28:27 +01:00
if ( ! $idwarehouse || $idwarehouse == - 1 ) {
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-11-15 07:47:35 +01:00
setEventMessages ( $langs -> trans ( 'ErrorFieldRequired' , $langs -> transnoentitiesnoconv ( " Warehouse " )), null , 'errors' );
2015-01-17 19:28:27 +01:00
$action = '' ;
2013-04-20 00:10:20 +02:00
}
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
if ( ! $error ) {
// On verifie si la facture a des paiements
$sql = 'SELECT pf.amount' ;
$sql .= ' FROM ' . MAIN_DB_PREFIX . 'paiement_facture as pf' ;
$sql .= ' WHERE pf.fk_facture = ' . $object -> id ;
$result = $db -> query ( $sql );
if ( $result ) {
$i = 0 ;
$num = $db -> num_rows ( $result );
while ( $i < $num ) {
$objp = $db -> fetch_object ( $result );
$totalpaye += $objp -> amount ;
$i ++ ;
}
} else {
dol_print_error ( $db , '' );
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$resteapayer = $object -> total_ttc - $totalpaye ;
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// On verifie si les lignes de factures ont ete exportees en compta et/ou ventilees
$ventilExportCompta = $object -> getVentilExportCompta ();
2014-10-27 19:37:30 +01:00
2015-01-17 19:28:27 +01:00
// On verifie si aucun paiement n'a ete effectue
2017-09-27 16:29:33 +02:00
if ( $ventilExportCompta == 0 )
2014-10-27 19:37:30 +01:00
{
2017-09-27 16:29:33 +02:00
if ( ! empty ( $conf -> global -> INVOICE_CAN_ALWAYS_BE_EDITED ) || ( $resteapayer == $object -> total_ttc && empty ( $object -> paye )))
{
$result = $object -> set_draft ( $user , $idwarehouse );
if ( $result < 0 ) setEventMessages ( $object -> error , $object -> errors , 'errors' );
2014-12-25 23:08:07 +01:00
2017-09-27 16:29:33 +02:00
// Define output language
if ( empty ( $conf -> global -> MAIN_DISABLE_PDF_AUTOUPDATE ))
{
$outputlangs = $langs ;
$newlang = '' ;
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang ) && GETPOST ( 'lang_id' , 'aZ09' )) $newlang = GETPOST ( 'lang_id' , 'aZ09' );
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang )) $newlang = $object -> thirdparty -> default_lang ;
if ( ! empty ( $newlang )) {
$outputlangs = new Translate ( " " , $conf );
$outputlangs -> setDefaultLang ( $newlang );
2018-02-08 12:58:47 +01:00
$outputlangs -> load ( 'products' );
2017-09-27 16:29:33 +02:00
}
$model = $object -> modelpdf ;
$ret = $object -> fetch ( $id ); // Reload to get new records
2014-12-25 23:08:07 +01:00
2017-09-27 16:29:33 +02:00
$object -> generateDocument ( $model , $outputlangs , $hidedetails , $hidedesc , $hideref );
}
2015-01-17 19:28:27 +01:00
}
2013-04-20 00:10:20 +02:00
}
}
}
2008-08-12 20:20:18 +02:00
2015-01-17 19:28:27 +01:00
// Classify "paid"
2018-11-14 14:59:36 +01:00
else if ( $action == 'confirm_paid' && $confirm == 'yes' && $usercanissuepayment )
2015-01-18 17:13:42 +01:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
$result = $object -> set_paid ( $user );
2015-11-15 07:47:35 +01:00
if ( $result < 0 ) setEventMessages ( $object -> error , $object -> errors , 'errors' );
2015-01-17 19:28:27 +01:00
} // Classif "paid partialy"
2018-11-14 14:59:36 +01:00
else if ( $action == 'confirm_paid_partially' && $confirm == 'yes' && $usercanissuepayment )
2015-01-18 17:13:42 +01:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
2018-03-12 12:27:40 +01:00
$close_code = GETPOST ( " close_code " , 'none' );
$close_note = GETPOST ( " close_note " , 'none' );
2015-01-17 19:28:27 +01:00
if ( $close_code ) {
$result = $object -> set_paid ( $user , $close_code , $close_note );
2015-11-15 07:47:35 +01:00
if ( $result < 0 ) setEventMessages ( $object -> error , $object -> errors , 'errors' );
2015-01-17 19:28:27 +01:00
} else {
2015-10-17 16:18:33 +02:00
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " Reason " )), null , 'errors' );
2015-01-17 19:28:27 +01:00
}
} // Classify "abandoned"
else if ( $action == 'confirm_canceled' && $confirm == 'yes' ) {
$object -> fetch ( $id );
2018-03-12 12:27:40 +01:00
$close_code = GETPOST ( " close_code " , 'none' );
$close_note = GETPOST ( " close_note " , 'none' );
2015-01-17 19:28:27 +01:00
if ( $close_code ) {
$result = $object -> set_canceled ( $user , $close_code , $close_note );
2015-11-15 07:47:35 +01:00
if ( $result < 0 ) setEventMessages ( $object -> error , $object -> errors , 'errors' );
2015-01-17 19:28:27 +01:00
} else {
2015-10-17 16:18:33 +02:00
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " Reason " )), null , 'errors' );
2015-01-17 19:28:27 +01:00
}
2013-04-20 00:10:20 +02:00
}
2008-08-12 20:20:18 +02:00
2015-01-17 19:28:27 +01:00
// Convertir en reduc
2018-11-14 14:59:36 +01:00
else if ( $action == 'confirm_converttoreduc' && $confirm == 'yes' && $usercancreate )
2013-04-20 00:10:20 +02:00
{
2015-01-17 19:28:27 +01:00
$object -> fetch ( $id );
$object -> fetch_thirdparty ();
//$object->fetch_lines(); // Already done into fetch
2014-03-19 22:30:25 +01:00
2015-01-17 19:28:27 +01:00
// Check if there is already a discount (protection to avoid duplicate creation when resubmit post)
$discountcheck = new DiscountAbsolute ( $db );
$result = $discountcheck -> fetch ( 0 , $object -> id );
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$canconvert = 0 ;
2017-11-17 15:07:32 +01:00
if ( $object -> type == Facture :: TYPE_DEPOSIT && empty ( $discountcheck -> id )) $canconvert = 1 ; // we can convert deposit into discount if deposit is payed (completely, partially or not at all) and not already converted (see real condition into condition used to show button converttoreduc)
2016-11-24 15:48:04 +01:00
if (( $object -> type == Facture :: TYPE_CREDIT_NOTE || $object -> type == Facture :: TYPE_STANDARD ) && $object -> paye == 0 && empty ( $discountcheck -> id )) $canconvert = 1 ; // we can convert credit note into discount if credit note is not payed back and not already converted and amount of payment is 0 (see real condition into condition used to show button converttoreduc)
2015-01-17 19:28:27 +01:00
if ( $canconvert )
{
$db -> begin ();
2014-03-01 19:45:13 +01:00
2017-04-30 12:55:11 +02:00
$amount_ht = $amount_tva = $amount_ttc = array ();
2017-06-07 16:44:04 +02:00
2017-04-30 12:55:11 +02:00
// Loop on each vat rate
2015-01-17 19:28:27 +01:00
$i = 0 ;
2015-02-15 19:13:16 +01:00
foreach ( $object -> lines as $line )
{
2018-02-04 09:05:35 +01:00
if ( $line -> product_type < 9 && $line -> total_ht != 0 ) // Remove lines with product_type greater than or equal to 9
2015-02-15 19:13:16 +01:00
{ // no need to create discount if amount is null
$amount_ht [ $line -> tva_tx ] += $line -> total_ht ;
$amount_tva [ $line -> tva_tx ] += $line -> total_tva ;
$amount_ttc [ $line -> tva_tx ] += $line -> total_ttc ;
2018-10-17 15:49:08 +02:00
$multicurrency_amount_ht [ $line -> tva_tx ] += $line -> multicurrency_total_ht ;
$multicurrency_amount_tva [ $line -> tva_tx ] += $line -> multicurrency_total_tva ;
$multicurrency_amount_ttc [ $line -> tva_tx ] += $line -> multicurrency_total_ttc ;
2015-02-07 23:33:37 +01:00
$i ++ ;
}
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Insert one discount by VAT rate category
$discount = new DiscountAbsolute ( $db );
if ( $object -> type == Facture :: TYPE_CREDIT_NOTE )
$discount -> description = '(CREDIT_NOTE)' ;
elseif ( $object -> type == Facture :: TYPE_DEPOSIT )
$discount -> description = '(DEPOSIT)' ;
2017-04-30 12:55:11 +02:00
elseif ( $object -> type == Facture :: TYPE_STANDARD || $object -> type == Facture :: TYPE_REPLACEMENT || $object -> type == Facture :: TYPE_SITUATION )
2016-11-24 15:48:04 +01:00
$discount -> description = '(EXCESS RECEIVED)' ;
2015-01-17 19:28:27 +01:00
else {
2015-11-15 07:47:35 +01:00
setEventMessages ( $langs -> trans ( 'CantConvertToReducAnInvoiceOfThisType' ), null , 'errors' );
2015-01-17 19:28:27 +01:00
}
$discount -> fk_soc = $object -> socid ;
$discount -> fk_facture_source = $object -> id ;
$error = 0 ;
2017-06-07 16:44:04 +02:00
if ( $object -> type == Facture :: TYPE_STANDARD || $object -> type == Facture :: TYPE_REPLACEMENT || $object -> type == Facture :: TYPE_SITUATION )
2017-04-30 12:55:11 +02:00
{
// If we're on a standard invoice, we have to get excess received to create a discount in TTC without VAT
2017-06-07 16:44:04 +02:00
2017-06-09 09:25:15 +02:00
$sql = 'SELECT SUM(pf.amount) as total_paiements' ;
2017-11-23 15:06:16 +01:00
$sql .= ' FROM ' . MAIN_DB_PREFIX . 'paiement_facture as pf, ' . MAIN_DB_PREFIX . 'paiement as p' ;
2018-03-07 17:32:57 +01:00
$sql .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'c_paiement as c ON p.fk_paiement = c.id' ;
2017-06-09 09:25:15 +02:00
$sql .= ' WHERE pf.fk_facture = ' . $object -> id ;
2017-11-23 15:06:16 +01:00
$sql .= ' AND pf.fk_paiement = p.rowid' ;
2018-11-15 17:27:49 +01:00
$sql .= ' AND p.entity IN (' . getEntity ( 'invoice' ) . ')' ;
2017-06-07 16:44:04 +02:00
2016-11-24 15:48:04 +01:00
$resql = $db -> query ( $sql );
2017-08-24 15:39:23 +02:00
if ( ! $resql ) dol_print_error ( $db );
2016-11-24 15:48:04 +01:00
$res = $db -> fetch_object ( $resql );
$total_paiements = $res -> total_paiements ;
2017-06-07 16:44:04 +02:00
2016-11-24 15:48:04 +01:00
$discount -> amount_ht = $discount -> amount_ttc = $total_paiements - $object -> total_ttc ;
$discount -> amount_tva = 0 ;
$discount -> tva_tx = 0 ;
2015-01-17 19:28:27 +01:00
$result = $discount -> create ( $user );
if ( $result < 0 )
{
$error ++ ;
}
2017-04-30 12:55:11 +02:00
}
if ( $object -> type == Facture :: TYPE_CREDIT_NOTE || $object -> type == Facture :: TYPE_DEPOSIT )
{
2016-11-24 15:48:04 +01:00
foreach ( $amount_ht as $tva_tx => $xxx )
{
$discount -> amount_ht = abs ( $amount_ht [ $tva_tx ]);
$discount -> amount_tva = abs ( $amount_tva [ $tva_tx ]);
$discount -> amount_ttc = abs ( $amount_ttc [ $tva_tx ]);
2018-10-17 15:49:08 +02:00
$discount -> multicurrency_amount_ht = abs ( $multicurrency_amount_ht [ $tva_tx ]);
$discount -> multicurrency_amount_tva = abs ( $multicurrency_amount_tva [ $tva_tx ]);
$discount -> multicurrency_amount_ttc = abs ( $multicurrency_amount_ttc [ $tva_tx ]);
2016-11-24 15:48:04 +01:00
$discount -> tva_tx = abs ( $tva_tx );
2017-06-07 16:44:04 +02:00
2016-11-24 15:48:04 +01:00
$result = $discount -> create ( $user );
if ( $result < 0 )
{
$error ++ ;
break ;
}
}
2015-01-17 19:28:27 +01:00
}
if ( empty ( $error ))
2013-04-20 00:10:20 +02:00
{
2017-11-11 12:07:55 +01:00
if ( $object -> type != Facture :: TYPE_DEPOSIT ) {
// Classe facture
$result = $object -> set_paid ( $user );
if ( $result >= 0 )
{
$db -> commit ();
}
else
{
setEventMessages ( $object -> error , $object -> errors , 'errors' );
$db -> rollback ();
}
} else {
2015-01-17 19:28:27 +01:00
$db -> commit ();
}
2013-04-20 00:10:20 +02:00
}
else
{
2015-11-15 07:47:35 +01:00
setEventMessages ( $discount -> error , $discount -> errors , 'errors' );
2013-04-20 00:10:20 +02:00
$db -> rollback ();
}
}
}
2008-08-12 20:20:18 +02:00
2017-12-03 11:59:16 +01:00
// Delete payment
2018-11-14 14:59:36 +01:00
elseif ( $action == 'confirm_delete_paiement' && $confirm == 'yes' && $usercancreate )
2017-12-03 11:59:16 +01:00
{
$object -> fetch ( $id );
if ( $object -> statut == Facture :: STATUS_VALIDATED && $object -> paye == 0 )
{
$paiement = new Paiement ( $db );
$result = $paiement -> fetch ( GETPOST ( 'paiement_id' ));
if ( $result > 0 ) {
$result = $paiement -> delete (); // If fetch ok and found
header ( " Location: " . $_SERVER [ 'PHP_SELF' ] . " ?id= " . $id );
}
if ( $result < 0 ) {
setEventMessages ( $paiement -> error , $paiement -> errors , 'errors' );
}
}
}
2015-01-17 19:28:27 +01:00
/*
* Insert new invoice in database
2016-04-24 18:55:19 +02:00
*/
2018-11-14 14:59:36 +01:00
else if ( $action == 'add' && $usercancreate )
2015-01-17 19:28:27 +01:00
{
if ( $socid > 0 ) $object -> socid = GETPOST ( 'socid' , 'int' );
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$db -> begin ();
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$error = 0 ;
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Fill array 'array_options' with data from add form
$extralabels = $extrafields -> fetch_name_optionals_label ( $object -> table_element );
$ret = $extrafields -> setOptionalsFromPost ( $extralabels , $object );
2015-02-26 14:25:30 +01:00
if ( $ret < 0 ) $error ++ ;
2014-03-01 19:45:13 +01:00
2015-01-18 17:13:42 +01:00
// Replacement invoice
2015-01-17 19:28:27 +01:00
if ( $_POST [ 'type' ] == Facture :: TYPE_REPLACEMENT )
2013-04-20 00:10:20 +02:00
{
2015-01-17 19:28:27 +01:00
$dateinvoice = dol_mktime ( 12 , 0 , 0 , $_POST [ 'remonth' ], $_POST [ 'reday' ], $_POST [ 'reyear' ]);
if ( empty ( $dateinvoice ))
{
$error ++ ;
2015-10-17 16:18:33 +02:00
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " Date " )), null , 'errors' );
2015-01-17 19:28:27 +01:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
if ( ! ( $_POST [ 'fac_replacement' ] > 0 )) {
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-10-17 16:18:33 +02:00
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " ReplaceInvoice " )), null , 'errors' );
2015-01-17 19:28:27 +01:00
}
2014-03-01 19:45:13 +01:00
2016-05-29 23:56:58 +02:00
$date_pointoftax = dol_mktime ( 12 , 0 , 0 , $_POST [ 'date_pointoftaxmonth' ], $_POST [ 'date_pointoftaxday' ], $_POST [ 'date_pointoftaxyear' ]);
2016-08-10 09:47:25 +02:00
2015-01-17 19:28:27 +01:00
if ( ! $error ) {
// This is a replacement invoice
$result = $object -> fetch ( $_POST [ 'fac_replacement' ]);
$object -> fetch_thirdparty ();
$object -> date = $dateinvoice ;
2016-05-29 23:56:58 +02:00
$object -> date_pointoftax = $date_pointoftax ;
2018-01-17 19:45:23 +01:00
$object -> note_public = trim ( GETPOST ( 'note_public' , 'none' ));
// We do not copy the private note
2015-01-17 19:28:27 +01:00
$object -> ref_client = $_POST [ 'ref_client' ];
$object -> ref_int = $_POST [ 'ref_int' ];
$object -> modelpdf = $_POST [ 'model' ];
$object -> fk_project = $_POST [ 'projectid' ];
$object -> cond_reglement_id = $_POST [ 'cond_reglement_id' ];
$object -> mode_reglement_id = $_POST [ 'mode_reglement_id' ];
2017-10-16 08:47:05 +02:00
$object -> fk_account = GETPOST ( 'fk_account' , 'int' );
2015-01-17 19:28:27 +01:00
$object -> remise_absolue = $_POST [ 'remise_absolue' ];
$object -> remise_percent = $_POST [ 'remise_percent' ];
2015-02-23 09:16:14 +01:00
$object -> fk_incoterms = GETPOST ( 'incoterm_id' , 'int' );
$object -> location_incoterms = GETPOST ( 'location_incoterms' , 'alpha' );
2016-01-23 16:01:55 +01:00
$object -> multicurrency_code = GETPOST ( 'multicurrency_code' , 'alpha' );
2018-01-17 19:45:23 +01:00
$object -> multicurrency_tx = GETPOST ( 'originmulticurrency_tx' , 'int' );
2018-11-14 17:34:27 +01:00
$object -> entity = ( GETPOSTISSET ( 'entity' ) ? GETPOST ( 'entity' , 'int' ) : $conf -> entity );
2016-04-24 18:55:19 +02:00
2015-01-17 19:28:27 +01:00
// Proprietes particulieres a facture de remplacement
$object -> fk_facture_source = $_POST [ 'fac_replacement' ];
$object -> type = Facture :: TYPE_REPLACEMENT ;
$id = $object -> createFromCurrent ( $user );
2015-01-18 17:13:42 +01:00
if ( $id <= 0 ) {
2015-11-15 07:47:35 +01:00
setEventMessages ( $object -> error , $object -> errors , 'errors' );
2015-01-18 17:13:42 +01:00
}
2014-07-20 01:09:43 +02:00
}
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Credit note invoice
if ( $_POST [ 'type' ] == Facture :: TYPE_CREDIT_NOTE )
2014-03-20 00:05:20 +01:00
{
2015-07-08 14:32:57 +02:00
$sourceinvoice = GETPOST ( 'fac_avoir' );
if ( ! ( $sourceinvoice > 0 ) && empty ( $conf -> global -> INVOICE_CREDIT_NOTE_STANDALONE ))
2015-01-17 19:28:27 +01:00
{
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-10-17 16:18:33 +02:00
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " CorrectInvoice " )), null , 'errors' );
2015-01-17 19:28:27 +01:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$dateinvoice = dol_mktime ( 12 , 0 , 0 , $_POST [ 'remonth' ], $_POST [ 'reday' ], $_POST [ 'reyear' ]);
if ( empty ( $dateinvoice ))
{
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-10-17 16:18:33 +02:00
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> trans ( " Date " )), null , 'errors' );
2015-01-17 19:28:27 +01:00
}
2014-03-01 19:45:13 +01:00
2016-05-29 23:56:58 +02:00
$date_pointoftax = dol_mktime ( 12 , 0 , 0 , $_POST [ 'date_pointoftaxmonth' ], $_POST [ 'date_pointoftaxday' ], $_POST [ 'date_pointoftaxyear' ]);
2016-08-10 09:47:25 +02:00
2015-01-17 19:28:27 +01:00
if ( ! $error )
2014-03-29 05:18:24 +01:00
{
2015-01-17 19:28:27 +01:00
$object -> socid = GETPOST ( 'socid' , 'int' );
2018-12-02 14:31:45 +01:00
$object -> number = $_POST [ 'ref' ];
2015-01-17 19:28:27 +01:00
$object -> date = $dateinvoice ;
2016-05-29 23:56:58 +02:00
$object -> date_pointoftax = $date_pointoftax ;
2018-01-17 19:45:23 +01:00
$object -> note_public = trim ( GETPOST ( 'note_public' , 'none' ));
// We do not copy the private note
2015-01-17 19:28:27 +01:00
$object -> ref_client = $_POST [ 'ref_client' ];
$object -> ref_int = $_POST [ 'ref_int' ];
$object -> modelpdf = $_POST [ 'model' ];
$object -> fk_project = $_POST [ 'projectid' ];
$object -> cond_reglement_id = 0 ;
$object -> mode_reglement_id = $_POST [ 'mode_reglement_id' ];
2017-10-16 08:47:05 +02:00
$object -> fk_account = GETPOST ( 'fk_account' , 'int' );
2015-01-17 19:28:27 +01:00
$object -> remise_absolue = $_POST [ 'remise_absolue' ];
$object -> remise_percent = $_POST [ 'remise_percent' ];
2015-02-23 09:16:14 +01:00
$object -> fk_incoterms = GETPOST ( 'incoterm_id' , 'int' );
$object -> location_incoterms = GETPOST ( 'location_incoterms' , 'alpha' );
2016-01-23 16:01:55 +01:00
$object -> multicurrency_code = GETPOST ( 'multicurrency_code' , 'alpha' );
2018-01-17 19:45:23 +01:00
$object -> multicurrency_tx = GETPOST ( 'originmulticurrency_tx' , 'int' );
2018-11-14 17:34:27 +01:00
$object -> entity = ( GETPOSTISSET ( 'entity' ) ? GETPOST ( 'entity' , 'int' ) : $conf -> entity );
2016-08-10 09:47:25 +02:00
2015-01-17 19:28:27 +01:00
// Proprietes particulieres a facture avoir
2015-07-08 14:32:57 +02:00
$object -> fk_facture_source = $sourceinvoice > 0 ? $sourceinvoice : '' ;
2015-01-17 19:28:27 +01:00
$object -> type = Facture :: TYPE_CREDIT_NOTE ;
2014-03-01 19:45:13 +01:00
2018-03-23 12:24:47 +01:00
$facture_source = new Facture ( $db ); // fetch origin object
if ( $facture_source -> fetch ( $object -> fk_facture_source ) > 0 )
{
if ( $facture_source -> type == Facture :: TYPE_SITUATION )
{
$object -> situation_counter = $facture_source -> situation_counter ;
$object -> situation_cycle_ref = $facture_source -> situation_cycle_ref ;
$facture_source -> fetchPreviousNextSituationInvoice ();
}
}
2015-01-17 19:28:27 +01:00
$id = $object -> create ( $user );
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
if ( GETPOST ( 'invoiceAvoirWithLines' , 'int' ) == 1 && $id > 0 )
{
2018-03-23 12:24:47 +01:00
if ( ! empty ( $facture_source -> lines ))
2017-10-16 08:47:05 +02:00
{
$fk_parent_line = 0 ;
foreach ( $facture_source -> lines as $line )
{
2018-02-20 12:48:28 +01:00
// Extrafields
if ( empty ( $conf -> global -> MAIN_EXTRAFIELDS_DISABLED ) && method_exists ( $line , 'fetch_optionals' )) {
// load extrafields
$line -> fetch_optionals ();
}
2017-10-16 08:47:05 +02:00
// Reset fk_parent_line for no child products and special product
if (( $line -> product_type != 9 && empty ( $line -> fk_parent_line )) || $line -> product_type == 9 ) {
$fk_parent_line = 0 ;
}
2018-05-23 08:16:24 +02:00
2018-03-19 15:50:56 +01:00
if ( $facture_source -> type == Facture :: TYPE_SITUATION )
{
2018-09-28 02:24:11 +02:00
$source_fk_prev_id = $line -> fk_prev_id ; // temporary storing situation invoice fk_prev_id
2018-09-25 09:54:58 +02:00
$line -> fk_prev_id = $line -> id ; // Credit note line need to be linked to the situation invoice it is create from
2018-05-23 08:16:24 +02:00
2018-03-19 15:50:56 +01:00
if ( ! empty ( $facture_source -> tab_previous_situation_invoice ))
{
2018-04-04 12:33:48 +02:00
// search the last invoice in cycle
2018-03-19 15:50:56 +01:00
$lineIndex = count ( $facture_source -> tab_previous_situation_invoice ) - 1 ;
2018-04-04 12:33:48 +02:00
$searchPreviousInvoice = true ;
while ( $searchPreviousInvoice )
{
if ( $facture_source -> tab_previous_situation_invoice [ $lineIndex ] -> type == Facture :: TYPE_SITUATION || $lineIndex < 1 )
{
$searchPreviousInvoice = false ; // find, exit;
break ;
}
2018-05-23 08:16:24 +02:00
else
2018-04-04 12:33:48 +02:00
{
2018-05-23 08:16:24 +02:00
$lineIndex -- ; // go to previous invoice in cycle
2018-04-04 12:33:48 +02:00
}
}
2018-05-23 08:16:24 +02:00
2018-03-19 15:50:56 +01:00
$maxPrevSituationPercent = 0 ;
foreach ( $facture_source -> tab_previous_situation_invoice [ $lineIndex ] -> lines as $prevLine )
{
2018-09-25 09:54:58 +02:00
if ( $prevLine -> id == $source_fk_prev_id )
2018-03-19 15:50:56 +01:00
{
$maxPrevSituationPercent = max ( $maxPrevSituationPercent , $prevLine -> situation_percent );
2018-05-23 08:16:24 +02:00
2018-03-19 15:50:56 +01:00
//$line->subprice = $line->subprice - $prevLine->subprice;
$line -> total_ht = $line -> total_ht - $prevLine -> total_ht ;
$line -> total_tva = $line -> total_tva - $prevLine -> total_tva ;
$line -> total_ttc = $line -> total_ttc - $prevLine -> total_ttc ;
$line -> total_localtax1 = $line -> total_localtax1 - $prevLine -> total_localtax1 ;
$line -> total_localtax2 = $line -> total_localtax2 - $prevLine -> total_localtax2 ;
2018-05-23 08:16:24 +02:00
2018-03-19 15:50:56 +01:00
$line -> multicurrency_subprice = $line -> multicurrency_subprice - $prevLine -> multicurrency_subprice ;
$line -> multicurrency_total_ht = $line -> multicurrency_total_ht - $prevLine -> multicurrency_total_ht ;
$line -> multicurrency_total_tva = $line -> multicurrency_total_tva - $prevLine -> multicurrency_total_tva ;
$line -> multicurrency_total_ttc = $line -> multicurrency_total_ttc - $prevLine -> multicurrency_total_ttc ;
}
}
2018-05-23 08:16:24 +02:00
2018-03-19 15:50:56 +01:00
// prorata
2018-03-23 12:24:47 +01:00
$line -> situation_percent = $maxPrevSituationPercent - $line -> situation_percent ;
2018-03-19 15:50:56 +01:00
}
}
2017-10-16 08:47:05 +02:00
$line -> fk_facture = $object -> id ;
$line -> fk_parent_line = $fk_parent_line ;
$line -> subprice = - $line -> subprice ; // invert price for object
$line -> pa_ht = $line -> pa_ht ; // we choosed to have buy/cost price always positive, so no revert of sign here
$line -> total_ht = - $line -> total_ht ;
$line -> total_tva = - $line -> total_tva ;
$line -> total_ttc = - $line -> total_ttc ;
$line -> total_localtax1 = - $line -> total_localtax1 ;
$line -> total_localtax2 = - $line -> total_localtax2 ;
$line -> multicurrency_subprice = - $line -> multicurrency_subprice ;
$line -> multicurrency_total_ht = - $line -> multicurrency_total_ht ;
$line -> multicurrency_total_tva = - $line -> multicurrency_total_tva ;
$line -> multicurrency_total_ttc = - $line -> multicurrency_total_ttc ;
$result = $line -> insert ( 0 , 1 ); // When creating credit note with same lines than source, we must ignore error if discount alreayd linked
$object -> lines [] = $line ; // insert new line in current object
// Defined the new fk_parent_line
if ( $result > 0 && $line -> product_type == 9 ) {
$fk_parent_line = $result ;
}
}
$object -> update_price ( 1 );
}
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2017-10-16 08:47:05 +02:00
if ( GETPOST ( 'invoiceAvoirWithPaymentRestAmount' , 'int' ) == 1 && $id > 0 )
{
if ( $facture_source -> fetch ( $object -> fk_facture_source ) > 0 )
{
$totalpaye = $facture_source -> getSommePaiement ();
$totalcreditnotes = $facture_source -> getSumCreditNotesUsed ();
$totaldeposits = $facture_source -> getSumDepositsUsed ();
$remain_to_pay = abs ( $facture_source -> total_ttc - $totalpaye - $totalcreditnotes - $totaldeposits );
$object -> addline ( $langs -> trans ( 'invoiceAvoirLineWithPaymentRestAmount' ), $remain_to_pay , 1 , 0 , 0 , 0 , 0 , 0 , '' , '' , 'TTC' );
}
}
2018-03-27 16:04:56 +02:00
// Add link between credit note and origin
if ( ! empty ( $object -> fk_facture_source )) {
$facture_source -> fetch ( $object -> fk_facture_source );
2018-04-24 11:48:26 +02:00
$facture_source -> fetchObjectLinked ();
2018-03-27 16:04:56 +02:00
2018-04-24 11:48:26 +02:00
if ( ! empty ( $facture_source -> linkedObjectsIds )) {
foreach ( $facture_source -> linkedObjectsIds as $sourcetype => $TIds ) {
$object -> add_object_linked ( $sourcetype , current ( $TIds ));
}
}
2018-03-27 16:04:56 +02:00
}
2015-01-17 19:28:27 +01:00
}
2014-02-23 20:10:05 +01:00
}
2014-03-01 19:45:13 +01:00
2016-07-28 19:02:23 +02:00
// Standard invoice or Deposit invoice, created from a Predefined template invoice
2016-01-08 16:30:43 +01:00
if (( $_POST [ 'type' ] == Facture :: TYPE_STANDARD || $_POST [ 'type' ] == Facture :: TYPE_DEPOSIT ) && GETPOST ( 'fac_rec' ) > 0 )
2013-04-20 00:10:20 +02:00
{
2015-01-17 19:28:27 +01:00
$dateinvoice = dol_mktime ( 12 , 0 , 0 , $_POST [ 'remonth' ], $_POST [ 'reday' ], $_POST [ 'reyear' ]);
if ( empty ( $dateinvoice ))
{
$error ++ ;
2015-10-17 16:18:33 +02:00
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " Date " )), null , 'errors' );
2015-01-17 19:28:27 +01:00
}
2014-03-01 19:45:13 +01:00
2016-05-29 23:56:58 +02:00
$date_pointoftax = dol_mktime ( 12 , 0 , 0 , $_POST [ 'date_pointoftaxmonth' ], $_POST [ 'date_pointoftaxday' ], $_POST [ 'date_pointoftaxyear' ]);
2016-08-10 09:47:25 +02:00
2015-01-17 19:28:27 +01:00
if ( ! $error )
{
2018-01-17 19:45:23 +01:00
$object -> socid = GETPOST ( 'socid' , 'int' );
$object -> type = $_POST [ 'type' ];
2018-12-02 14:31:45 +01:00
$object -> number = $_POST [ 'ref' ];
2016-05-29 23:56:58 +02:00
$object -> date = $dateinvoice ;
$object -> date_pointoftax = $date_pointoftax ;
2018-01-17 19:45:23 +01:00
$object -> note_public = trim ( GETPOST ( 'note_public' , 'none' ));
$object -> note_private = trim ( GETPOST ( 'note_private' , 'none' ));
$object -> ref_client = $_POST [ 'ref_client' ];
$object -> ref_int = $_POST [ 'ref_int' ];
$object -> modelpdf = $_POST [ 'model' ];
$object -> fk_project = $_POST [ 'projectid' ];
2016-04-24 18:55:19 +02:00
$object -> cond_reglement_id = ( $_POST [ 'type' ] == 3 ? 1 : $_POST [ 'cond_reglement_id' ]);
$object -> mode_reglement_id = $_POST [ 'mode_reglement_id' ];
2017-10-16 08:47:05 +02:00
$object -> fk_account = GETPOST ( 'fk_account' , 'int' );
2016-04-24 18:55:19 +02:00
$object -> amount = $_POST [ 'amount' ];
$object -> remise_absolue = $_POST [ 'remise_absolue' ];
$object -> remise_percent = $_POST [ 'remise_percent' ];
$object -> fk_incoterms = GETPOST ( 'incoterm_id' , 'int' );
$object -> location_incoterms = GETPOST ( 'location_incoterms' , 'alpha' );
2016-01-23 16:01:55 +01:00
$object -> multicurrency_code = GETPOST ( 'multicurrency_code' , 'alpha' );
2018-01-17 19:45:23 +01:00
$object -> multicurrency_tx = GETPOST ( 'originmulticurrency_tx' , 'int' );
2018-11-14 17:34:27 +01:00
$object -> entity = ( GETPOSTISSET ( 'entity' ) ? GETPOST ( 'entity' , 'int' ) : $conf -> entity );
2016-08-10 09:47:25 +02:00
2015-01-17 19:28:27 +01:00
// Source facture
2018-01-17 19:45:23 +01:00
$object -> fac_rec = GETPOST ( 'fac_rec' , 'int' );
2014-03-01 19:45:13 +01:00
2018-01-17 19:45:23 +01:00
$id = $object -> create ( $user ); // This include recopy of links from recurring invoice and invoice lines
2015-01-17 19:28:27 +01:00
}
2014-02-23 20:10:05 +01:00
}
2014-03-01 19:45:13 +01:00
2016-12-04 21:27:08 +01:00
// Standard or deposit or proforma invoice, not from a Predefined template invoice
2016-01-08 16:30:43 +01:00
if (( $_POST [ 'type' ] == Facture :: TYPE_STANDARD || $_POST [ 'type' ] == Facture :: TYPE_DEPOSIT || $_POST [ 'type' ] == Facture :: TYPE_PROFORMA || ( $_POST [ 'type' ] == Facture :: TYPE_SITUATION && empty ( $_POST [ 'situations' ]))) && GETPOST ( 'fac_rec' ) <= 0 )
2014-03-29 05:18:24 +01:00
{
2015-01-17 19:28:27 +01:00
if ( GETPOST ( 'socid' , 'int' ) < 1 )
{
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-10-17 16:18:33 +02:00
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " Customer " )), null , 'errors' );
2014-11-14 16:43:49 +01:00
}
2015-01-17 19:28:27 +01:00
$dateinvoice = dol_mktime ( 12 , 0 , 0 , $_POST [ 'remonth' ], $_POST [ 'reday' ], $_POST [ 'reyear' ]);
if ( empty ( $dateinvoice ))
2014-05-25 05:01:14 +02:00
{
2015-01-17 19:28:27 +01:00
$error ++ ;
2015-10-17 16:18:33 +02:00
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " Date " )), null , 'errors' );
2015-01-17 19:28:27 +01:00
}
2014-03-01 19:45:13 +01:00
2016-05-29 23:56:58 +02:00
$date_pointoftax = dol_mktime ( 12 , 0 , 0 , $_POST [ 'date_pointoftaxmonth' ], $_POST [ 'date_pointoftaxday' ], $_POST [ 'date_pointoftaxyear' ]);
2016-08-10 09:47:25 +02:00
2015-01-17 19:28:27 +01:00
if ( ! $error )
2014-05-25 05:01:14 +02:00
{
2015-01-17 19:28:27 +01:00
// Si facture standard
$object -> socid = GETPOST ( 'socid' , 'int' );
$object -> type = GETPOST ( 'type' );
2018-12-02 14:31:45 +01:00
$object -> number = $_POST [ 'ref' ];
2015-01-17 19:28:27 +01:00
$object -> date = $dateinvoice ;
2016-05-29 23:56:58 +02:00
$object -> date_pointoftax = $date_pointoftax ;
2018-01-17 19:45:23 +01:00
$object -> note_public = trim ( GETPOST ( 'note_public' , 'none' ));
$object -> note_private = trim ( GETPOST ( 'note_private' , 'none' ));
2015-01-17 19:28:27 +01:00
$object -> ref_client = $_POST [ 'ref_client' ];
$object -> ref_int = $_POST [ 'ref_int' ];
$object -> modelpdf = $_POST [ 'model' ];
$object -> fk_project = $_POST [ 'projectid' ];
$object -> cond_reglement_id = ( $_POST [ 'type' ] == 3 ? 1 : $_POST [ 'cond_reglement_id' ]);
$object -> mode_reglement_id = $_POST [ 'mode_reglement_id' ];
2017-10-16 08:47:05 +02:00
$object -> fk_account = GETPOST ( 'fk_account' , 'int' );
2015-01-17 19:28:27 +01:00
$object -> amount = $_POST [ 'amount' ];
$object -> remise_absolue = $_POST [ 'remise_absolue' ];
$object -> remise_percent = $_POST [ 'remise_percent' ];
2015-02-23 09:16:14 +01:00
$object -> fk_incoterms = GETPOST ( 'incoterm_id' , 'int' );
$object -> location_incoterms = GETPOST ( 'location_incoterms' , 'alpha' );
2016-01-23 16:01:55 +01:00
$object -> multicurrency_code = GETPOST ( 'multicurrency_code' , 'alpha' );
2018-01-17 19:45:23 +01:00
$object -> multicurrency_tx = GETPOST ( 'originmulticurrency_tx' , 'int' );
2018-11-14 17:34:27 +01:00
$object -> entity = ( GETPOSTISSET ( 'entity' ) ? GETPOST ( 'entity' , 'int' ) : $conf -> entity );
2015-01-17 19:28:27 +01:00
2015-01-18 18:44:22 +01:00
if ( GETPOST ( 'type' ) == Facture :: TYPE_SITUATION )
{
$object -> situation_counter = 1 ;
$object -> situation_final = 0 ;
$object -> situation_cycle_ref = $object -> newCycle ();
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$object -> fetch_thirdparty ();
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// If creation from another object of another module (Example: origin=propal, originid=1)
2016-02-25 16:27:28 +01:00
if ( ! empty ( $origin ) && ! empty ( $originid ))
2014-09-26 10:11:38 +02:00
{
2015-01-17 19:28:27 +01:00
// Parse element/subelement (ex: project_task)
2015-01-18 17:13:42 +01:00
$element = $subelement = $origin ;
if ( preg_match ( '/^([^_]+)_([^_]+)/i' , $origin , $regs )) {
2015-01-17 19:28:27 +01:00
$element = $regs [ 1 ];
$subelement = $regs [ 2 ];
}
2014-09-29 20:39:19 +02:00
2015-01-17 19:28:27 +01:00
// For compatibility
if ( $element == 'order' ) {
$element = $subelement = 'commande' ;
}
if ( $element == 'propal' ) {
$element = 'comm/propal' ;
$subelement = 'propal' ;
}
if ( $element == 'contract' ) {
$element = $subelement = 'contrat' ;
}
if ( $element == 'inter' ) {
$element = $subelement = 'ficheinter' ;
}
if ( $element == 'shipping' ) {
$element = $subelement = 'expedition' ;
}
2014-03-01 19:45:13 +01:00
2015-01-18 17:13:42 +01:00
$object -> origin = $origin ;
$object -> origin_id = $originid ;
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Possibility to add external linked objects with hooks
2015-01-18 17:13:42 +01:00
$object -> linked_objects [ $object -> origin ] = $object -> origin_id ;
// link with order if it is a shipping invoice
if ( $object -> origin == 'shipping' )
{
require_once DOL_DOCUMENT_ROOT . '/expedition/class/expedition.class.php' ;
$exp = new Expedition ( $db );
$exp -> fetch ( $object -> origin_id );
$exp -> fetchObjectLinked ();
2017-12-02 15:03:14 +01:00
if ( is_array ( $exp -> linkedObjectsIds [ 'commande' ]) && count ( $exp -> linkedObjectsIds [ 'commande' ]) > 0 ) {
2015-09-12 23:42:48 +02:00
foreach ( $exp -> linkedObjectsIds [ 'commande' ] as $key => $value ){
$object -> linked_objects [ 'commande' ] = $value ;
}
}
2015-01-18 17:13:42 +01:00
}
2014-09-29 20:39:19 +02:00
2015-01-18 17:13:42 +01:00
if ( is_array ( $_POST [ 'other_linked_objects' ]) && ! empty ( $_POST [ 'other_linked_objects' ]))
2014-05-25 05:01:14 +02:00
{
2015-01-17 19:28:27 +01:00
$object -> linked_objects = array_merge ( $object -> linked_objects , $_POST [ 'other_linked_objects' ]);
}
2014-03-01 19:45:13 +01:00
2016-07-28 19:02:23 +02:00
$id = $object -> create ( $user ); // This include class to add_object_linked() and add add_contact()
2017-06-07 16:44:04 +02:00
2015-01-17 19:28:27 +01:00
if ( $id > 0 )
2014-05-25 05:01:14 +02:00
{
2016-02-25 01:00:13 +01:00
dol_include_once ( '/' . $element . '/class/' . $subelement . '.class.php' );
$classname = ucfirst ( $subelement );
$srcobject = new $classname ( $db );
dol_syslog ( " Try to find source object origin= " . $object -> origin . " originid= " . $object -> origin_id . " to add lines or deposit lines " );
$result = $srcobject -> fetch ( $object -> origin_id );
2016-07-19 07:46:27 +02:00
2017-10-16 08:47:05 +02:00
// If deposit invoice
2015-01-18 17:13:42 +01:00
if ( $_POST [ 'type' ] == Facture :: TYPE_DEPOSIT )
2014-05-25 05:01:14 +02:00
{
2015-01-17 19:28:27 +01:00
$typeamount = GETPOST ( 'typedeposit' , 'alpha' );
$valuedeposit = GETPOST ( 'valuedeposit' , 'int' );
2017-02-07 11:09:18 +01:00
$amountdeposit = array ();
if ( ! empty ( $conf -> global -> MAIN_DEPOSIT_MULTI_TVA ))
2015-01-17 19:28:27 +01:00
{
2017-02-07 11:09:18 +01:00
if ( $typeamount == 'amount' ) $amount = $valuedeposit ;
else $amount = $srcobject -> total_ttc * ( $valuedeposit / 100 );
2017-06-07 16:44:04 +02:00
2017-02-07 11:09:18 +01:00
$TTotalByTva = array ();
foreach ( $srcobject -> lines as & $line )
{
2017-11-11 16:10:06 +01:00
if ( ! empty ( $line -> special_code )) continue ;
2017-02-07 11:09:18 +01:00
$TTotalByTva [ $line -> tva_tx ] += $line -> total_ttc ;
}
2017-06-07 16:44:04 +02:00
2017-02-07 11:09:18 +01:00
$amount_to_diff = 0 ;
foreach ( $TTotalByTva as $tva => & $total )
{
$coef = $total / $srcobject -> total_ttc ; // Calc coef
$am = $amount * $coef ;
$amount_ttc_diff += $am ;
$amountdeposit [ $tva ] += $am / ( 1 + $tva / 100 ); // Convert into HT for the addline
}
2015-01-17 19:28:27 +01:00
}
else
{
2017-02-07 11:09:18 +01:00
if ( $typeamount == 'amount' )
2015-01-17 19:28:27 +01:00
{
2017-05-05 14:49:25 +02:00
$amountdeposit [ 0 ] = $valuedeposit ;
2017-02-07 11:09:18 +01:00
}
else
2015-01-17 19:28:27 +01:00
{
2017-02-07 11:09:18 +01:00
if ( $result > 0 )
2015-01-17 19:28:27 +01:00
{
2017-02-07 11:09:18 +01:00
$totalamount = 0 ;
$lines = $srcobject -> lines ;
$numlines = count ( $lines );
for ( $i = 0 ; $i < $numlines ; $i ++ )
{
$qualified = 1 ;
if ( empty ( $lines [ $i ] -> qty )) $qualified = 0 ; // We discard qty=0, it is an option
if ( ! empty ( $lines [ $i ] -> special_code )) $qualified = 0 ; // We discard special_code (frais port, ecotaxe, option, ...)
2017-02-07 11:14:27 +01:00
if ( $qualified ) $totalamount += $lines [ $i ] -> total_ht ; // Fixme : is it not for the customer ? Shouldn't we take total_ttc ?
2017-02-07 11:09:18 +01:00
}
if ( $totalamount != 0 ) {
2017-05-15 10:26:40 +02:00
if ( $numlines > 0 ) $numlines = $numlines - 1 ;
2017-10-16 08:47:05 +02:00
$tva_tx = $lines [ $numlines ] -> tva_tx ;
if ( ! empty ( $lines [ $numlines ] -> vat_src_code ) && ! preg_match ( '/\(/' , $tva_tx )) $tva_tx .= ' (' . $lines [ $numlines ] -> vat_src_code . ')' ;
2017-05-05 14:49:25 +02:00
$amountdeposit [ $tva_tx ] = ( $totalamount * $valuedeposit ) / 100 ;
2017-02-09 17:41:06 +01:00
} else {
2017-05-05 14:49:25 +02:00
$amountdeposit [ 0 ] = 0 ;
2017-02-07 11:09:18 +01:00
}
} else {
setEventMessages ( $srcobject -> error , $srcobject -> errors , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-01-17 19:28:27 +01:00
}
}
2017-06-07 16:44:04 +02:00
2017-02-07 11:09:18 +01:00
$amount_ttc_diff = $amountdeposit [ 0 ];
2015-01-17 19:28:27 +01:00
}
2017-06-07 16:44:04 +02:00
2017-02-07 11:09:18 +01:00
foreach ( $amountdeposit as $tva => $amount )
{
2017-07-25 11:32:41 +02:00
$arraylist = array ( 'amount' => 'FixAmount' , 'variable' => 'VarAmount' );
$descline = $langs -> trans ( 'Deposit' );
2018-07-06 12:45:20 +02:00
//$descline.= ' - '.$langs->trans($arraylist[$typeamount]);
2017-07-25 11:32:41 +02:00
if ( $typeamount == 'amount' ) {
$descline .= ' (' . price ( $valuedeposit , '' , $langs , 0 , - 1 , - 1 , ( ! empty ( $object -> multicurrency_code ) ? $object -> multicurrency_code : $conf -> currency )) . ')' ;
} elseif ( $typeamount == 'variable' ) {
$descline .= ' (' . $valuedeposit . '%)' ;
}
$descline .= ' - ' . $srcobject -> ref ;
2017-02-07 11:09:18 +01:00
$result = $object -> addline (
2017-07-25 11:32:41 +02:00
$descline ,
2017-02-07 11:09:18 +01:00
$amount , // subprice
1 , // quantity
$tva , // vat rate
0 , // localtax1_tx
0 , // localtax2_tx
( empty ( $conf -> global -> INVOICE_PRODUCTID_DEPOSIT ) ? 0 : $conf -> global -> INVOICE_PRODUCTID_DEPOSIT ), // fk_product
0 , // remise_percent
0 , // date_start
0 , // date_end
2017-06-07 16:44:04 +02:00
0 ,
2017-10-16 08:47:05 +02:00
$lines [ $i ] -> info_bits , // info_bits
2017-02-27 00:12:48 +01:00
0 ,
2017-02-07 11:09:18 +01:00
'HT' ,
0 ,
0 , // product_type
1 ,
$lines [ $i ] -> special_code ,
$object -> origin ,
0 ,
0 ,
0 ,
2017-07-25 11:32:41 +02:00
0
//,$langs->trans('Deposit') //Deprecated
2017-02-07 11:09:18 +01:00
);
}
2017-06-07 16:44:04 +02:00
2017-02-07 11:09:18 +01:00
$diff = $object -> total_ttc - $amount_ttc_diff ;
2017-06-07 16:44:04 +02:00
2017-02-24 16:19:00 +01:00
if ( ! empty ( $conf -> global -> MAIN_DEPOSIT_MULTI_TVA ) && $diff != 0 )
2017-02-07 11:09:18 +01:00
{
$object -> fetch_lines ();
2017-05-11 11:41:00 +02:00
$subprice_diff = $object -> lines [ 0 ] -> subprice - $diff / ( 1 + $object -> lines [ 0 ] -> tva_tx / 100 );
2017-02-07 11:09:18 +01:00
$object -> updateline ( $object -> lines [ 0 ] -> id , $object -> lines [ 0 ] -> desc , $subprice_diff , $object -> lines [ 0 ] -> qty , $object -> lines [ 0 ] -> remise_percent , $object -> lines [ 0 ] -> date_start , $object -> lines [ 0 ] -> date_end , $object -> lines [ 0 ] -> tva_tx , 0 , 0 , 'HT' , $object -> lines [ 0 ] -> info_bits , $object -> lines [ 0 ] -> product_type , 0 , 0 , 0 , $object -> lines [ 0 ] -> pa_ht , $object -> lines [ 0 ] -> label , 0 , array (), 100 );
}
2014-05-25 05:01:14 +02:00
}
else
{
if ( $result > 0 )
{
2013-04-20 17:10:03 +02:00
$lines = $srcobject -> lines ;
2015-01-17 19:28:27 +01:00
if ( empty ( $lines ) && method_exists ( $srcobject , 'fetch_lines' ))
2013-04-20 00:10:20 +02:00
{
2015-01-17 19:28:27 +01:00
$srcobject -> fetch_lines ();
$lines = $srcobject -> lines ;
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$fk_parent_line = 0 ;
$num = count ( $lines );
for ( $i = 0 ; $i < $num ; $i ++ )
2014-05-25 05:01:14 +02:00
{
2015-01-18 17:13:42 +01:00
// Don't add lines with qty 0 when coming from a shipment including all order lines
if ( $srcobject -> element == 'shipping' && $conf -> global -> SHIPMENT_GETS_ALL_ORDER_PRODUCTS && $lines [ $i ] -> qty == 0 ) continue ;
2018-10-27 09:19:02 +02:00
// Don't add closed lines when coming from a contract
if ( $srcobject -> element == 'contrat' && $lines [ $i ] -> statut == 5 ) continue ;
2015-01-18 17:13:42 +01:00
2015-01-17 19:28:27 +01:00
$label = ( ! empty ( $lines [ $i ] -> label ) ? $lines [ $i ] -> label : '' );
$desc = ( ! empty ( $lines [ $i ] -> desc ) ? $lines [ $i ] -> desc : $lines [ $i ] -> libelle );
2015-01-18 18:44:22 +01:00
if ( $object -> situation_counter == 1 ) $lines [ $i ] -> situation_percent = 0 ;
2015-01-17 19:28:27 +01:00
2015-01-18 17:13:42 +01:00
if ( $lines [ $i ] -> subprice < 0 )
2015-01-17 19:28:27 +01:00
{
// Negative line, we create a discount line
$discount = new DiscountAbsolute ( $db );
$discount -> fk_soc = $object -> socid ;
2015-01-18 17:13:42 +01:00
$discount -> amount_ht = abs ( $lines [ $i ] -> total_ht );
$discount -> amount_tva = abs ( $lines [ $i ] -> total_tva );
$discount -> amount_ttc = abs ( $lines [ $i ] -> total_ttc );
$discount -> tva_tx = $lines [ $i ] -> tva_tx ;
2015-01-17 19:28:27 +01:00
$discount -> fk_user = $user -> id ;
$discount -> description = $desc ;
$discountid = $discount -> create ( $user );
if ( $discountid > 0 ) {
$result = $object -> insert_discount ( $discountid ); // This include link_to_invoice
} else {
2015-11-18 16:05:41 +01:00
setEventMessages ( $discount -> error , $discount -> errors , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-01-17 19:28:27 +01:00
break ;
}
2014-02-23 20:10:05 +01:00
} else {
2015-01-17 19:28:27 +01:00
// Positive line
2015-01-18 17:13:42 +01:00
$product_type = ( $lines [ $i ] -> product_type ? $lines [ $i ] -> product_type : 0 );
2015-01-17 19:28:27 +01:00
// Date start
$date_start = false ;
2015-01-18 17:13:42 +01:00
if ( $lines [ $i ] -> date_debut_prevue )
$date_start = $lines [ $i ] -> date_debut_prevue ;
if ( $lines [ $i ] -> date_debut_reel )
$date_start = $lines [ $i ] -> date_debut_reel ;
if ( $lines [ $i ] -> date_start )
$date_start = $lines [ $i ] -> date_start ;
2015-01-17 19:28:27 +01:00
// Date end
$date_end = false ;
2015-01-18 17:13:42 +01:00
if ( $lines [ $i ] -> date_fin_prevue )
$date_end = $lines [ $i ] -> date_fin_prevue ;
if ( $lines [ $i ] -> date_fin_reel )
$date_end = $lines [ $i ] -> date_fin_reel ;
if ( $lines [ $i ] -> date_end )
$date_end = $lines [ $i ] -> date_end ;
2015-01-17 19:28:27 +01:00
// Reset fk_parent_line for no child products and special product
2015-01-18 17:13:42 +01:00
if (( $lines [ $i ] -> product_type != 9 && empty ( $lines [ $i ] -> fk_parent_line )) || $lines [ $i ] -> product_type == 9 ) {
2015-01-17 19:28:27 +01:00
$fk_parent_line = 0 ;
}
// Extrafields
2015-01-18 17:13:42 +01:00
if ( empty ( $conf -> global -> MAIN_EXTRAFIELDS_DISABLED ) && method_exists ( $lines [ $i ], 'fetch_optionals' )) {
$lines [ $i ] -> fetch_optionals ( $lines [ $i ] -> rowid );
2015-02-28 04:59:27 +01:00
$array_options = $lines [ $i ] -> array_options ;
2015-01-17 19:28:27 +01:00
}
2017-05-02 21:27:56 +02:00
$tva_tx = $lines [ $i ] -> tva_tx ;
if ( ! empty ( $lines [ $i ] -> vat_src_code ) && ! preg_match ( '/\(/' , $tva_tx )) $tva_tx .= ' (' . $lines [ $i ] -> vat_src_code . ')' ;
2017-06-07 16:44:04 +02:00
2017-05-02 21:27:56 +02:00
// View third's localtaxes for NOW and do not use value from origin.
// TODO Is this really what we want ? Yes if source if template invoice but what if proposal or order ?
$localtax1_tx = get_localtax ( $tva_tx , 1 , $object -> thirdparty );
$localtax2_tx = get_localtax ( $tva_tx , 2 , $object -> thirdparty );
2015-01-17 19:28:27 +01:00
2018-05-27 15:04:12 +02:00
$result = $object -> addline (
$desc , $lines [ $i ] -> subprice , $lines [ $i ] -> qty , $tva_tx , $localtax1_tx , $localtax2_tx , $lines [ $i ] -> fk_product ,
$lines [ $i ] -> remise_percent , $date_start , $date_end , 0 , $lines [ $i ] -> info_bits , $lines [ $i ] -> fk_remise_except ,
'HT' , 0 , $product_type , $lines [ $i ] -> rang , $lines [ $i ] -> special_code , $object -> origin , $lines [ $i ] -> rowid ,
$fk_parent_line , $lines [ $i ] -> fk_fournprice , $lines [ $i ] -> pa_ht , $label , $array_options ,
$lines [ $i ] -> situation_percent , $lines [ $i ] -> fk_prev_id , $lines [ $i ] -> fk_unit
);
2015-01-17 19:28:27 +01:00
if ( $result > 0 ) {
$lineid = $result ;
} else {
$lineid = 0 ;
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-01-17 19:28:27 +01:00
break ;
}
// Defined the new fk_parent_line
2015-01-18 17:13:42 +01:00
if ( $result > 0 && $lines [ $i ] -> product_type == 9 ) {
2015-01-17 19:28:27 +01:00
$fk_parent_line = $result ;
}
2013-04-20 17:10:03 +02:00
}
2013-04-20 00:10:20 +02:00
}
2014-02-23 20:10:05 +01:00
} else {
2015-11-15 07:47:35 +01:00
setEventMessages ( $srcobject -> error , $srcobject -> errors , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
2013-04-20 00:10:20 +02:00
}
2013-04-20 17:10:03 +02:00
}
2016-07-19 07:46:27 +02:00
2016-02-25 01:00:13 +01:00
// Now we create same links to contact than the ones found on origin object
2017-09-11 13:39:03 +02:00
/* Useless , already into the create
2016-02-25 16:27:28 +01:00
if ( ! empty ( $conf -> global -> MAIN_PROPAGATE_CONTACTS_FROM_ORIGIN ))
2016-02-25 01:00:13 +01:00
{
$originforcontact = $object -> origin ;
$originidforcontact = $object -> origin_id ;
if ( $originforcontact == 'shipping' ) // shipment and order share the same contacts. If creating from shipment we take data of order
{
$originforcontact = $srcobject -> origin ;
$originidforcontact = $srcobject -> origin_id ;
}
$sqlcontact = " SELECT code, fk_socpeople FROM " . MAIN_DB_PREFIX . " element_contact as ec, " . MAIN_DB_PREFIX . " c_type_contact as ctc " ;
$sqlcontact .= " WHERE element_id = " . $originidforcontact . " AND ec.fk_c_type_contact = ctc.rowid AND ctc.element = ' " . $originforcontact . " ' " ;
2016-07-19 07:46:27 +02:00
2016-02-25 01:00:13 +01:00
$resqlcontact = $db -> query ( $sqlcontact );
if ( $resqlcontact )
{
while ( $objcontact = $db -> fetch_object ( $resqlcontact ))
{
2016-07-19 07:46:27 +02:00
//print $objcontact->code.'-'.$objcontact->fk_socpeople."\n";
2016-02-25 01:00:13 +01:00
$object -> add_contact ( $objcontact -> fk_socpeople , $objcontact -> code );
}
}
2016-08-10 09:47:25 +02:00
else dol_print_error ( $resqlcontact );
2017-09-11 13:39:03 +02:00
} */
2016-08-10 09:47:25 +02:00
2016-02-25 16:27:28 +01:00
// Hooks
$parameters = array ( 'objFrom' => $srcobject );
$reshook = $hookmanager -> executeHooks ( 'createFrom' , $parameters , $object , $action ); // Note that $action and $object may have been
// modified by hook
if ( $reshook < 0 )
2016-07-21 10:30:51 +02:00
{
2017-10-16 08:47:05 +02:00
setEventMessages ( $hookmanager -> error , $hookmanager -> errors , 'errors' );
$error ++ ;
2016-07-19 07:46:27 +02:00
}
2015-01-17 19:28:27 +01:00
} else {
2015-11-15 07:47:35 +01:00
setEventMessages ( $object -> error , $object -> errors , 'errors' );
2016-02-25 16:27:28 +01:00
$error ++ ;
2014-05-25 05:01:14 +02:00
}
2016-07-19 07:46:27 +02:00
}
else
2016-02-25 01:00:13 +01:00
{ // If some invoice's lines coming from page
2015-01-17 19:28:27 +01:00
$id = $object -> create ( $user );
2016-05-29 23:56:58 +02:00
for ( $i = 1 ; $i <= $NBLINES ; $i ++ ) {
2015-01-17 19:28:27 +01:00
if ( $_POST [ 'idprod' . $i ]) {
$product = new Product ( $db );
$product -> fetch ( $_POST [ 'idprod' . $i ]);
$startday = dol_mktime ( 12 , 0 , 0 , $_POST [ 'date_start' . $i . 'month' ], $_POST [ 'date_start' . $i . 'day' ], $_POST [ 'date_start' . $i . 'year' ]);
$endday = dol_mktime ( 12 , 0 , 0 , $_POST [ 'date_end' . $i . 'month' ], $_POST [ 'date_end' . $i . 'day' ], $_POST [ 'date_end' . $i . 'year' ]);
2015-02-26 14:15:33 +01:00
$result = $object -> addline ( $product -> description , $product -> price , $_POST [ 'qty' . $i ], $product -> tva_tx , $product -> localtax1_tx , $product -> localtax2_tx , $_POST [ 'idprod' . $i ], $_POST [ 'remise_percent' . $i ], $startday , $endday , 0 , 0 , '' , $product -> price_base_type , $product -> price_ttc , $product -> type , - 1 , 0 , '' , 0 , 0 , null , 0 , '' , 0 , 100 , '' , $product -> fk_unit );
2015-01-17 19:28:27 +01:00
}
2013-04-20 00:10:20 +02:00
}
}
}
}
2014-03-01 19:45:13 +01:00
2018-03-12 12:27:40 +01:00
// Situation invoices
2015-01-18 18:44:22 +01:00
if ( GETPOST ( 'type' ) == Facture :: TYPE_SITUATION && ( ! empty ( $_POST [ 'situations' ])))
{
$datefacture = dol_mktime ( 12 , 0 , 0 , $_POST [ 'remonth' ], $_POST [ 'reday' ], $_POST [ 'reyear' ]);
if ( empty ( $datefacture )) {
$error ++ ;
$mesg = '<div class="error">' . $langs -> trans ( " ErrorFieldRequired " , $langs -> trans ( " Date " )) . '</div>' ;
}
2014-03-01 19:45:13 +01:00
2016-05-29 23:56:58 +02:00
$date_pointoftax = dol_mktime ( 12 , 0 , 0 , $_POST [ 'date_pointoftaxmonth' ], $_POST [ 'date_pointoftaxday' ], $_POST [ 'date_pointoftaxyear' ]);
2016-08-10 09:47:25 +02:00
2015-01-18 18:44:22 +01:00
if ( ! ( $_POST [ 'situations' ] > 0 )) {
$error ++ ;
$mesg = '<div class="error">' . $langs -> trans ( " ErrorFieldRequired " , $langs -> trans ( " InvoiceSituation " )) . '</div>' ;
}
2014-03-01 19:45:13 +01:00
2015-01-18 18:44:22 +01:00
if ( ! $error ) {
$result = $object -> fetch ( $_POST [ 'situations' ]);
$object -> fk_facture_source = $_POST [ 'situations' ];
$object -> type = Facture :: TYPE_SITUATION ;
2016-01-13 13:42:58 +01:00
if ( ! empty ( $origin ) && ! empty ( $originid ))
{
$object -> origin = $origin ;
$object -> origin_id = $originid ;
2016-08-10 09:47:25 +02:00
2018-05-14 14:55:33 +02:00
foreach ( $object -> lines as $i => & $line )
2016-01-13 13:42:58 +01:00
{
$line -> origin = $object -> origin ;
$line -> origin_id = $line -> id ;
2018-10-11 10:14:22 +02:00
$line -> fk_prev_id = $line -> id ;
2017-09-19 18:42:29 +02:00
$line -> fetch_optionals ( $line -> id );
2018-09-28 02:24:11 +02:00
$line -> situation_percent = $line -> get_prev_progress ( $object -> id ); // get good progress including credit note
2018-05-14 14:55:33 +02:00
// Si fk_remise_except defini on vérifie si la réduction à déjà été appliquée
if ( $line -> fk_remise_except )
{
$discount = new DiscountAbsolute ( $line -> db );
$result = $discount -> fetch ( $line -> fk_remise_except );
if ( $result > 0 )
{
// Check if discount not already affected to another invoice
if ( $discount -> fk_facture_line > 0 )
{
2018-05-18 11:02:04 +02:00
$line -> fk_remise_except = 0 ;
2018-05-14 14:55:33 +02:00
}
}
}
2016-01-13 13:42:58 +01:00
}
}
2015-01-18 18:44:22 +01:00
$object -> fetch_thirdparty ();
$object -> date = $datefacture ;
2016-05-29 23:56:58 +02:00
$object -> date_pointoftax = $date_pointoftax ;
2018-03-12 12:27:40 +01:00
$object -> note_public = trim ( GETPOST ( 'note_public' , 'none' ));
$object -> note = trim ( GETPOST ( 'note' , 'none' ));
$object -> ref_client = GETPOST ( 'ref_client' , 'alpha' );
$object -> ref_int = GETPOST ( 'ref_int' , 'alpha' );
$object -> modelpdf = GETPOST ( 'model' , 'alpha' );
$object -> fk_project = GETPOST ( 'projectid' , 'int' );
$object -> cond_reglement_id = GETPOST ( 'cond_reglement_id' , 'int' );
$object -> mode_reglement_id = GETPOST ( 'mode_reglement_id' , 'int' );
$object -> remise_absolue = GETPOST ( 'remise_absolue' , 'int' );
$object -> remise_percent = GETPOST ( 'remise_percent' , 'int' );
2015-01-18 18:44:22 +01:00
// Proprietes particulieres a facture de remplacement
$object -> situation_counter = $object -> situation_counter + 1 ;
$id = $object -> createFromCurrent ( $user );
2017-09-27 16:29:33 +02:00
if ( $id <= 0 )
2017-09-19 18:42:29 +02:00
{
$mesg = $object -> error ;
}
else
{
$nextSituationInvoice = new Facture ( $db );
$nextSituationInvoice -> fetch ( $id );
// create extrafields with data from create form
$extralabels = $extrafields -> fetch_name_optionals_label ( $nextSituationInvoice -> table_element );
$ret = $extrafields -> setOptionalsFromPost ( $extralabels , $nextSituationInvoice );
if ( $ret > 0 ) {
$nextSituationInvoice -> insertExtraFields ();
}
}
2015-01-18 18:44:22 +01:00
}
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// End of object creation, we show it
if ( $id > 0 && ! $error )
{
$db -> commit ();
2017-01-16 20:24:26 +01:00
// Define output language
if ( empty ( $conf -> global -> MAIN_DISABLE_PDF_AUTOUPDATE ) && count ( $object -> lines ))
{
$outputlangs = $langs ;
$newlang = '' ;
2017-06-27 17:27:01 +02:00
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang ) && GETPOST ( 'lang_id' , 'aZ09' )) $newlang = GETPOST ( 'lang_id' , 'aZ09' );
2017-01-16 20:24:26 +01:00
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang )) $newlang = $object -> thirdparty -> default_lang ;
if ( ! empty ( $newlang )) {
$outputlangs = new Translate ( " " , $conf );
$outputlangs -> setDefaultLang ( $newlang );
2018-02-08 12:53:26 +01:00
$outputlangs -> load ( 'products' );
2017-01-16 20:24:26 +01:00
}
$model = $object -> modelpdf ;
$ret = $object -> fetch ( $id ); // Reload to get new records
$result = $object -> generateDocument ( $model , $outputlangs , $hidedetails , $hidedesc , $hideref );
if ( $result < 0 ) setEventMessages ( $object -> error , $object -> errors , 'errors' );
}
2015-01-17 19:28:27 +01:00
header ( 'Location: ' . $_SERVER [ " PHP_SELF " ] . '?facid=' . $id );
exit ();
}
else
{
$db -> rollback ();
$action = 'create' ;
2015-01-18 17:13:42 +01:00
$_GET [ " origin " ] = $_POST [ " origin " ];
$_GET [ " originid " ] = $_POST [ " originid " ];
setEventMessages ( $object -> error , $object -> errors , 'errors' );
2015-01-17 19:28:27 +01:00
}
2013-04-20 00:10:20 +02:00
}
2014-09-02 13:46:47 +02:00
2015-01-17 19:28:27 +01:00
// Add a new line
2018-11-14 14:59:36 +01:00
else if ( $action == 'addline' && $usercancreate )
2014-03-20 00:05:20 +01:00
{
2015-01-17 19:28:27 +01:00
$langs -> load ( 'errors' );
$error = 0 ;
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Set if we used free entry or predefined product
$predef = '' ;
2018-03-12 12:27:40 +01:00
$product_desc = ( GETPOST ( 'dp_desc' , 'none' ) ? GETPOST ( 'dp_desc' , 'none' ) : '' );
2015-01-17 19:28:27 +01:00
$price_ht = GETPOST ( 'price_ht' );
2016-12-10 19:54:16 +01:00
$price_ht_devise = GETPOST ( 'multicurrency_price_ht' );
2017-05-29 10:41:51 +02:00
$prod_entry_mode = GETPOST ( 'prod_entry_mode' , 'alpha' );
2016-07-23 16:37:21 +02:00
if ( $prod_entry_mode == 'free' )
2015-01-17 19:28:27 +01:00
{
$idprod = 0 ;
2018-03-12 12:27:40 +01:00
$tva_tx = ( GETPOST ( 'tva_tx' , 'alpha' ) ? GETPOST ( 'tva_tx' , 'alpha' ) : 0 );
2015-01-17 19:28:27 +01:00
}
else
{
$idprod = GETPOST ( 'idprod' , 'int' );
$tva_tx = '' ;
2013-06-10 16:05:41 +02:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$qty = GETPOST ( 'qty' . $predef );
$remise_percent = GETPOST ( 'remise_percent' . $predef );
// Extrafields
$extrafieldsline = new ExtraFields ( $db );
$extralabelsline = $extrafieldsline -> fetch_name_optionals_label ( $object -> table_element_line );
2015-02-28 04:59:27 +01:00
$array_options = $extrafieldsline -> getOptionalsFromPost ( $extralabelsline , $predef );
2015-01-17 19:28:27 +01:00
// Unset extrafield
if ( is_array ( $extralabelsline )) {
// Get extra fields
foreach ( $extralabelsline as $key => $value ) {
unset ( $_POST [ " options_ " . $key . $predef ]);
}
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
if ( empty ( $idprod ) && ( $price_ht < 0 ) && ( $qty < 0 )) {
2015-11-15 07:47:35 +01:00
setEventMessages ( $langs -> trans ( 'ErrorBothFieldCantBeNegative' , $langs -> transnoentitiesnoconv ( 'UnitPriceHT' ), $langs -> transnoentitiesnoconv ( 'Qty' )), null , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-01-17 19:28:27 +01:00
}
2017-10-16 08:47:05 +02:00
if ( ! $prod_entry_mode )
{
if ( GETPOST ( 'type' ) < 0 && ! GETPOST ( 'search_idprod' ))
{
setEventMessages ( $langs -> trans ( 'ErrorChooseBetweenFreeEntryOrPredefinedProduct' ), null , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
2017-10-16 08:47:05 +02:00
}
}
2016-07-23 16:37:21 +02:00
if ( $prod_entry_mode == 'free' && empty ( $idprod ) && GETPOST ( 'type' ) < 0 ) {
2017-10-16 08:47:05 +02:00
setEventMessages ( $langs -> trans ( 'ErrorFieldRequired' , $langs -> transnoentitiesnoconv ( 'Type' )), null , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-01-17 19:28:27 +01:00
}
2018-01-29 16:21:54 +01:00
if ( $prod_entry_mode == 'free' && empty ( $idprod ) && (( $price_ht < 0 && empty ( $conf -> global -> FACTURE_ENABLE_NEGATIVE_LINES )) || $price_ht == '' ) && $price_ht_devise == '' ) // Unit price can be 0 but not ''
2015-01-17 19:28:27 +01:00
{
2018-09-04 10:37:29 +02:00
if ( $price_ht < 0 && empty ( $conf -> global -> FACTURE_ENABLE_NEGATIVE_LINES ))
{
$langs -> load ( " errors " );
setEventMessages ( $langs -> trans ( " ErrorFieldCantBeNegativeOnInvoice " , $langs -> transnoentitiesnoconv ( " UnitPriceHT " )), null , 'errors' );
$error ++ ;
}
else
{
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " UnitPriceHT " )), null , 'errors' );
$error ++ ;
}
2015-01-17 19:28:27 +01:00
}
if ( $qty == '' ) {
2015-11-15 07:47:35 +01:00
setEventMessages ( $langs -> trans ( 'ErrorFieldRequired' , $langs -> transnoentitiesnoconv ( 'Qty' )), null , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-01-17 19:28:27 +01:00
}
2016-07-23 16:37:21 +02:00
if ( $prod_entry_mode == 'free' && empty ( $idprod ) && empty ( $product_desc )) {
2015-11-15 07:47:35 +01:00
setEventMessages ( $langs -> trans ( 'ErrorFieldRequired' , $langs -> transnoentitiesnoconv ( 'Description' )), null , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-01-17 19:28:27 +01:00
}
2015-01-18 17:13:42 +01:00
if ( $qty < 0 ) {
$langs -> load ( " errors " );
2015-11-15 07:47:35 +01:00
setEventMessages ( $langs -> trans ( 'ErrorQtyForCustomerInvoiceCantBeNegative' ), null , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-01-18 17:13:42 +01:00
}
2016-07-23 16:37:21 +02:00
2017-02-08 12:37:38 +01:00
if ( ! $error && ! empty ( $conf -> variants -> enabled ) && $prod_entry_mode != 'free' ) {
2016-07-23 16:37:21 +02:00
if ( $combinations = GETPOST ( 'combinations' , 'array' )) {
//Check if there is a product with the given combination
$prodcomb = new ProductCombination ( $db );
if ( $res = $prodcomb -> fetchByProductCombination2ValuePairs ( $idprod , $combinations )) {
$idprod = $res -> fk_product_child ;
2018-07-26 11:57:25 +02:00
}
else
2018-07-24 18:28:56 +02:00
{
setEventMessages ( $langs -> trans ( 'ErrorProductCombinationNotFound' ), null , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
2016-07-23 16:37:21 +02:00
}
}
}
2015-01-17 19:28:27 +01:00
if ( ! $error && ( $qty >= 0 ) && ( ! empty ( $product_desc ) || ! empty ( $idprod ))) {
2016-07-23 16:37:21 +02:00
2015-01-17 19:28:27 +01:00
$ret = $object -> fetch ( $id );
if ( $ret < 0 ) {
dol_print_error ( $db , $object -> error );
exit ();
}
$ret = $object -> fetch_thirdparty ();
// Clean parameters
$date_start = dol_mktime ( GETPOST ( 'date_start' . $predef . 'hour' ), GETPOST ( 'date_start' . $predef . 'min' ), GETPOST ( 'date_start' . $predef . 'sec' ), GETPOST ( 'date_start' . $predef . 'month' ), GETPOST ( 'date_start' . $predef . 'day' ), GETPOST ( 'date_start' . $predef . 'year' ));
$date_end = dol_mktime ( GETPOST ( 'date_end' . $predef . 'hour' ), GETPOST ( 'date_end' . $predef . 'min' ), GETPOST ( 'date_end' . $predef . 'sec' ), GETPOST ( 'date_end' . $predef . 'month' ), GETPOST ( 'date_end' . $predef . 'day' ), GETPOST ( 'date_end' . $predef . 'year' ));
$price_base_type = ( GETPOST ( 'price_base_type' , 'alpha' ) ? GETPOST ( 'price_base_type' , 'alpha' ) : 'HT' );
// Define special_code for special lines
$special_code = 0 ;
// if (empty($_POST['qty'])) $special_code=3; // Options should not exists on invoices
// Ecrase $pu par celui du produit
// Ecrase $desc par celui du produit
2017-03-04 21:45:19 +01:00
// Ecrase $tva_tx par celui du produit
2015-01-17 19:28:27 +01:00
// Ecrase $base_price_type par celui du produit
2015-02-26 14:15:33 +01:00
// Replaces $fk_unit with the product's
2016-07-19 07:46:27 +02:00
if ( ! empty ( $idprod ))
2015-10-25 22:50:05 +01:00
{
2015-01-17 19:28:27 +01:00
$prod = new Product ( $db );
$prod -> fetch ( $idprod );
$label = (( GETPOST ( 'product_label' ) && GETPOST ( 'product_label' ) != $prod -> label ) ? GETPOST ( 'product_label' ) : '' );
// Update if prices fields are defined
2017-03-04 21:45:19 +01:00
$tva_tx = get_default_tva ( $mysoc , $object -> thirdparty , $prod -> id );
$tva_npr = get_default_npr ( $mysoc , $object -> thirdparty , $prod -> id );
if ( empty ( $tva_tx )) $tva_npr = 0 ;
2016-07-19 07:46:27 +02:00
2017-03-04 21:45:19 +01:00
$pu_ht = $prod -> price ;
$pu_ttc = $prod -> price_ttc ;
$price_min = $prod -> price_min ;
$price_base_type = $prod -> price_base_type ;
2015-01-17 19:28:27 +01:00
2018-01-09 14:20:47 +01:00
// If price per segment
2017-03-04 21:45:19 +01:00
if ( ! empty ( $conf -> global -> PRODUIT_MULTIPRICES ) && ! empty ( $object -> thirdparty -> price_level ))
{
$pu_ht = $prod -> multiprices [ $object -> thirdparty -> price_level ];
$pu_ttc = $prod -> multiprices_ttc [ $object -> thirdparty -> price_level ];
$price_min = $prod -> multiprices_min [ $object -> thirdparty -> price_level ];
$price_base_type = $prod -> multiprices_base_type [ $object -> thirdparty -> price_level ];
if ( ! empty ( $conf -> global -> PRODUIT_MULTIPRICES_USE_VAT_PER_LEVEL )) // using this option is a bug. kept for backward compatibility
2015-01-17 19:28:27 +01:00
{
2017-10-16 08:47:05 +02:00
if ( isset ( $prod -> multiprices_tva_tx [ $object -> thirdparty -> price_level ])) $tva_tx = $prod -> multiprices_tva_tx [ $object -> thirdparty -> price_level ];
if ( isset ( $prod -> multiprices_recuperableonly [ $object -> thirdparty -> price_level ])) $tva_npr = $prod -> multiprices_recuperableonly [ $object -> thirdparty -> price_level ];
2017-03-04 21:45:19 +01:00
if ( empty ( $tva_tx )) $tva_npr = 0 ;
2014-05-25 05:01:14 +02:00
}
2017-03-04 21:45:19 +01:00
}
2018-01-09 14:20:47 +01:00
// If price per customer
2017-03-04 21:45:19 +01:00
elseif ( ! empty ( $conf -> global -> PRODUIT_CUSTOMER_PRICES ))
{
require_once DOL_DOCUMENT_ROOT . '/product/class/productcustomerprice.class.php' ;
2014-03-01 19:45:13 +01:00
2017-03-04 21:45:19 +01:00
$prodcustprice = new Productcustomerprice ( $db );
2014-03-01 19:45:13 +01:00
2017-03-04 21:45:19 +01:00
$filter = array ( 't.fk_product' => $prod -> id , 't.fk_soc' => $object -> thirdparty -> id );
2014-03-01 19:45:13 +01:00
2017-03-04 21:45:19 +01:00
$result = $prodcustprice -> fetch_all ( '' , '' , 0 , 0 , $filter );
if ( $result ) {
if ( count ( $prodcustprice -> lines ) > 0 ) {
$pu_ht = price ( $prodcustprice -> lines [ 0 ] -> price );
$pu_ttc = price ( $prodcustprice -> lines [ 0 ] -> price_ttc );
$price_base_type = $prodcustprice -> lines [ 0 ] -> price_base_type ;
$tva_tx = $prodcustprice -> lines [ 0 ] -> tva_tx ;
2017-11-13 14:02:17 +01:00
if ( $prodcustprice -> lines [ 0 ] -> default_vat_code && ! preg_match ( '/\(.*\)/' , $tva_tx )) $tva_tx .= ' (' . $prodcustprice -> lines [ 0 ] -> default_vat_code . ')' ;
$tva_npr = $prodcustprice -> lines [ 0 ] -> recuperableonly ;
if ( empty ( $tva_tx )) $tva_npr = 0 ;
2015-01-17 19:28:27 +01:00
}
}
2017-03-04 21:45:19 +01:00
}
2018-01-09 14:20:47 +01:00
// If price per quantity
elseif ( ! empty ( $conf -> global -> PRODUIT_CUSTOMER_PRICES_BY_QTY ))
{
if ( $prod -> prices_by_qty [ 0 ]) // yes, this product has some prices per quantity
{
// Search the correct price into loaded array product_price_by_qty using id of array retrieved into POST['pqp'].
$pqp = GETPOST ( 'pbq' , 'int' );
// Search price into product_price_by_qty from $prod->id
foreach ( $prod -> prices_by_qty_list [ 0 ] as $priceforthequantityarray )
{
if ( $priceforthequantityarray [ 'rowid' ] != $pqp ) continue ;
// We found the price
if ( $priceforthequantityarray [ 'price_base_type' ] == 'HT' )
{
$pu_ht = $priceforthequantityarray [ 'unitprice' ];
}
else
{
$pu_ttc = $priceforthequantityarray [ 'unitprice' ];
}
// Note: the remise_percent or price by qty is used to set data on form, so we will use value from POST.
break ;
}
}
}
// If price per quantity and customer
2018-01-10 13:20:43 +01:00
elseif ( ! empty ( $conf -> global -> PRODUIT_CUSTOMER_PRICES_BY_QTY_MULTIPRICES ))
2018-01-09 14:20:47 +01:00
{
2018-05-23 17:05:08 +02:00
if ( $prod -> prices_by_qty [ $object -> thirdparty -> price_level ]) // yes, this product has some prices per quantity
{
// Search the correct price into loaded array product_price_by_qty using id of array retrieved into POST['pqp'].
$pqp = GETPOST ( 'pbq' , 'int' );
// Search price into product_price_by_qty from $prod->id
foreach ( $prod -> prices_by_qty_list [ $object -> thirdparty -> price_level ] as $priceforthequantityarray )
{
if ( $priceforthequantityarray [ 'rowid' ] != $pqp ) continue ;
// We found the price
if ( $priceforthequantityarray [ 'price_base_type' ] == 'HT' )
{
$pu_ht = $priceforthequantityarray [ 'unitprice' ];
}
else
{
$pu_ttc = $priceforthequantityarray [ 'unitprice' ];
}
// Note: the remise_percent or price by qty is used to set data on form, so we will use value from POST.
break ;
}
}
2018-01-09 14:20:47 +01:00
}
2014-03-01 19:45:13 +01:00
2017-03-04 21:45:19 +01:00
$tmpvat = price2num ( preg_replace ( '/\s*\(.*\)/' , '' , $tva_tx ));
$tmpprodvat = price2num ( preg_replace ( '/\s*\(.*\)/' , '' , $prod -> tva_tx ));
2017-06-07 16:44:04 +02:00
2017-03-04 21:45:19 +01:00
// if price ht was forced (ie: from gui when calculated by margin rate and cost price). TODO Why this ?
if ( ! empty ( $price_ht ))
{
$pu_ht = price2num ( $price_ht , 'MU' );
$pu_ttc = price2num ( $pu_ht * ( 1 + ( $tmpvat / 100 )), 'MU' );
}
// On reevalue prix selon taux tva car taux tva transaction peut etre different
// de ceux du produit par defaut (par exemple si pays different entre vendeur et acheteur).
elseif ( $tmpvat != $tmpprodvat )
{
if ( $price_base_type != 'HT' )
2015-10-25 22:50:05 +01:00
{
2017-03-04 21:45:19 +01:00
$pu_ht = price2num ( $pu_ttc / ( 1 + ( $tmpvat / 100 )), 'MU' );
2015-01-17 19:28:27 +01:00
}
2017-03-04 21:45:19 +01:00
else
2015-10-25 22:50:05 +01:00
{
2017-03-04 21:45:19 +01:00
$pu_ttc = price2num ( $pu_ht * ( 1 + ( $tmpvat / 100 )), 'MU' );
2013-04-20 00:10:20 +02:00
}
2017-03-04 21:45:19 +01:00
}
2014-03-01 19:45:13 +01:00
2017-03-04 21:45:19 +01:00
$desc = '' ;
2014-03-01 19:45:13 +01:00
2017-03-04 21:45:19 +01:00
// Define output language
if ( ! empty ( $conf -> global -> MAIN_MULTILANGS ) && ! empty ( $conf -> global -> PRODUIT_TEXTS_IN_THIRDPARTY_LANGUAGE )) {
$outputlangs = $langs ;
$newlang = '' ;
2017-06-27 17:27:01 +02:00
if ( empty ( $newlang ) && GETPOST ( 'lang_id' , 'aZ09' ))
$newlang = GETPOST ( 'lang_id' , 'aZ09' );
2017-03-04 21:45:19 +01:00
if ( empty ( $newlang ))
$newlang = $object -> thirdparty -> default_lang ;
if ( ! empty ( $newlang )) {
$outputlangs = new Translate ( " " , $conf );
$outputlangs -> setDefaultLang ( $newlang );
2018-02-08 12:53:26 +01:00
$outputlangs -> load ( 'products' );
2013-04-20 00:10:20 +02:00
}
2014-11-14 16:43:49 +01:00
2017-03-04 21:45:19 +01:00
$desc = ( ! empty ( $prod -> multilangs [ $outputlangs -> defaultlang ] [ " description " ])) ? $prod -> multilangs [ $outputlangs -> defaultlang ] [ " description " ] : $prod -> description ;
} else {
$desc = $prod -> description ;
}
2018-11-21 09:57:44 +01:00
$desc = dol_concatdesc ( $desc , $product_desc , '' , ! empty ( $conf -> global -> CHANGE_ORDER_CONCAT_DESCRIPTION ));
2017-03-04 21:45:19 +01:00
// Add custom code and origin country into description
if ( empty ( $conf -> global -> MAIN_PRODUCT_DISABLE_CUSTOMCOUNTRYCODE ) && ( ! empty ( $prod -> customcode ) || ! empty ( $prod -> country_code ))) {
$tmptxt = '(' ;
2017-12-08 10:41:14 +01:00
// Define output language
if ( ! empty ( $conf -> global -> MAIN_MULTILANGS ) && ! empty ( $conf -> global -> PRODUIT_TEXTS_IN_THIRDPARTY_LANGUAGE )) {
$outputlangs = $langs ;
$newlang = '' ;
if ( empty ( $newlang ) && GETPOST ( 'lang_id' , 'alpha' ))
$newlang = GETPOST ( 'lang_id' , 'alpha' );
if ( empty ( $newlang ))
$newlang = $object -> thirdparty -> default_lang ;
if ( ! empty ( $newlang )) {
$outputlangs = new Translate ( " " , $conf );
$outputlangs -> setDefaultLang ( $newlang );
2017-12-08 11:00:23 +01:00
$outputlangs -> load ( 'products' );
2017-12-08 10:41:14 +01:00
}
if ( ! empty ( $prod -> customcode ))
$tmptxt .= $outputlangs -> transnoentitiesnoconv ( " CustomCode " ) . ': ' . $prod -> customcode ;
if ( ! empty ( $prod -> customcode ) && ! empty ( $prod -> country_code ))
$tmptxt .= ' - ' ;
if ( ! empty ( $prod -> country_code ))
$tmptxt .= $outputlangs -> transnoentitiesnoconv ( " CountryOrigin " ) . ': ' . getCountry ( $prod -> country_code , 0 , $db , $outputlangs , 0 );
} else {
if ( ! empty ( $prod -> customcode ))
$tmptxt .= $langs -> transnoentitiesnoconv ( " CustomCode " ) . ': ' . $prod -> customcode ;
if ( ! empty ( $prod -> customcode ) && ! empty ( $prod -> country_code ))
$tmptxt .= ' - ' ;
if ( ! empty ( $prod -> country_code ))
$tmptxt .= $langs -> transnoentitiesnoconv ( " CountryOrigin " ) . ': ' . getCountry ( $prod -> country_code , 0 , $db , $langs , 0 );
}
2017-03-04 21:45:19 +01:00
$tmptxt .= ')' ;
$desc = dol_concatdesc ( $desc , $tmptxt );
}
2014-11-14 16:43:49 +01:00
2015-01-17 19:28:27 +01:00
$type = $prod -> type ;
2015-02-26 14:15:33 +01:00
$fk_unit = $prod -> fk_unit ;
2015-01-17 19:28:27 +01:00
} else {
$pu_ht = price2num ( $price_ht , 'MU' );
$pu_ttc = price2num ( GETPOST ( 'price_ttc' ), 'MU' );
$tva_npr = ( preg_match ( '/\*/' , $tva_tx ) ? 1 : 0 );
$tva_tx = str_replace ( '*' , '' , $tva_tx );
2016-02-27 11:32:49 +01:00
if ( empty ( $tva_tx )) $tva_npr = 0 ;
2015-01-17 19:28:27 +01:00
$label = ( GETPOST ( 'product_label' ) ? GETPOST ( 'product_label' ) : '' );
$desc = $product_desc ;
$type = GETPOST ( 'type' );
2015-04-21 15:49:58 +02:00
$fk_unit = GETPOST ( 'units' , 'alpha' );
2016-12-10 19:54:16 +01:00
$pu_ht_devise = price2num ( $price_ht_devise , 'MU' );
2015-01-17 19:28:27 +01:00
}
2014-11-14 16:43:49 +01:00
2015-01-17 19:28:27 +01:00
// Margin
$fournprice = price2num ( GETPOST ( 'fournprice' . $predef ) ? GETPOST ( 'fournprice' . $predef ) : '' );
2015-11-14 15:28:25 +01:00
$buyingprice = price2num ( GETPOST ( 'buying_price' . $predef ) != '' ? GETPOST ( 'buying_price' . $predef ) : '' ); // If buying_price is '0', we must keep this value
2014-11-14 16:43:49 +01:00
2015-01-17 19:28:27 +01:00
// Local Taxes
2016-02-27 11:32:49 +01:00
$localtax1_tx = get_localtax ( $tva_tx , 1 , $object -> thirdparty , $mysoc , $tva_npr );
$localtax2_tx = get_localtax ( $tva_tx , 2 , $object -> thirdparty , $mysoc , $tva_npr );
2016-07-19 07:46:27 +02:00
2015-01-17 19:28:27 +01:00
$info_bits = 0 ;
if ( $tva_npr )
$info_bits |= 0x01 ;
2014-11-14 16:43:49 +01:00
2018-11-14 14:59:36 +01:00
if ( $usercanproductignorepricemin && ( ! empty ( $price_min ) && ( price2num ( $pu_ht ) * ( 1 - price2num ( $remise_percent ) / 100 ) < price2num ( $price_min )))) {
2015-01-17 19:28:27 +01:00
$mesg = $langs -> trans ( " CantBeLessThanMinPrice " , price ( price2num ( $price_min , 'MU' ), 0 , $langs , 0 , 0 , - 1 , $conf -> currency ));
2015-11-15 07:47:35 +01:00
setEventMessages ( $mesg , null , 'errors' );
2015-01-17 19:28:27 +01:00
} else {
// Insert line
2016-12-10 19:54:16 +01:00
$result = $object -> addline ( $desc , $pu_ht , $qty , $tva_tx , $localtax1_tx , $localtax2_tx , $idprod , $remise_percent , $date_start , $date_end , 0 , $info_bits , '' , $price_base_type , $pu_ttc , $type , - 1 , $special_code , '' , 0 , GETPOST ( 'fk_parent_line' ), $fournprice , $buyingprice , $label , $array_options , $_POST [ 'progress' ], '' , $fk_unit , $pu_ht_devise );
2008-08-12 20:20:18 +02:00
2015-01-18 17:13:42 +01:00
if ( $result > 0 )
{
// Define output language
if ( empty ( $conf -> global -> MAIN_DISABLE_PDF_AUTOUPDATE ))
{
2015-01-17 19:28:27 +01:00
$outputlangs = $langs ;
2015-01-18 17:13:42 +01:00
$newlang = '' ;
2017-06-27 17:27:01 +02:00
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang ) && GETPOST ( 'lang_id' , 'aZ09' )) $newlang = GETPOST ( 'lang_id' , 'aZ09' );
2015-01-18 17:13:42 +01:00
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang )) $newlang = $object -> thirdparty -> default_lang ;
2015-01-17 19:28:27 +01:00
if ( ! empty ( $newlang )) {
$outputlangs = new Translate ( " " , $conf );
$outputlangs -> setDefaultLang ( $newlang );
2018-02-08 12:53:26 +01:00
$outputlangs -> load ( 'products' );
2013-04-20 17:10:03 +02:00
}
2015-01-18 17:13:42 +01:00
$model = $object -> modelpdf ;
2015-01-17 19:28:27 +01:00
$ret = $object -> fetch ( $id ); // Reload to get new records
2015-01-18 17:13:42 +01:00
2015-05-03 20:07:16 +02:00
$result = $object -> generateDocument ( $model , $outputlangs , $hidedetails , $hidedesc , $hideref );
2015-08-31 13:00:24 +02:00
if ( $result < 0 ) setEventMessages ( $object -> error , $object -> errors , 'errors' );
2013-04-20 00:10:20 +02:00
}
2014-05-05 14:30:08 +02:00
2015-01-18 17:13:42 +01:00
unset ( $_POST [ 'prod_entry_mode' ]);
2015-01-17 19:28:27 +01:00
unset ( $_POST [ 'qty' ]);
unset ( $_POST [ 'type' ]);
unset ( $_POST [ 'remise_percent' ]);
unset ( $_POST [ 'price_ht' ]);
2016-04-12 14:10:27 +02:00
unset ( $_POST [ 'multicurrency_price_ht' ]);
2015-01-17 19:28:27 +01:00
unset ( $_POST [ 'price_ttc' ]);
unset ( $_POST [ 'tva_tx' ]);
unset ( $_POST [ 'product_ref' ]);
unset ( $_POST [ 'product_label' ]);
unset ( $_POST [ 'product_desc' ]);
unset ( $_POST [ 'fournprice' ]);
unset ( $_POST [ 'buying_price' ]);
unset ( $_POST [ 'np_marginRate' ]);
unset ( $_POST [ 'np_markRate' ]);
unset ( $_POST [ 'dp_desc' ]);
unset ( $_POST [ 'idprod' ]);
2015-02-26 14:15:33 +01:00
unset ( $_POST [ 'units' ]);
2015-01-17 19:28:27 +01:00
2017-10-16 08:47:05 +02:00
unset ( $_POST [ 'date_starthour' ]);
unset ( $_POST [ 'date_startmin' ]);
unset ( $_POST [ 'date_startsec' ]);
unset ( $_POST [ 'date_startday' ]);
unset ( $_POST [ 'date_startmonth' ]);
unset ( $_POST [ 'date_startyear' ]);
unset ( $_POST [ 'date_endhour' ]);
unset ( $_POST [ 'date_endmin' ]);
unset ( $_POST [ 'date_endsec' ]);
unset ( $_POST [ 'date_endday' ]);
unset ( $_POST [ 'date_endmonth' ]);
unset ( $_POST [ 'date_endyear' ]);
2015-01-18 18:44:22 +01:00
unset ( $_POST [ 'situations' ]);
unset ( $_POST [ 'progress' ]);
2014-02-23 20:10:05 +01:00
} else {
2015-11-15 07:47:35 +01:00
setEventMessages ( $object -> error , $object -> errors , 'errors' );
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$action = '' ;
2013-04-20 00:10:20 +02:00
}
2013-06-10 16:05:41 +02:00
}
}
2014-03-01 19:45:13 +01:00
2018-11-14 14:59:36 +01:00
elseif ( $action == 'updateline' && $usercancreate && ! GETPOST ( 'cancel' , 'alpha' ))
2013-04-20 00:10:20 +02:00
{
2015-01-18 17:13:42 +01:00
if ( ! $object -> fetch ( $id ) > 0 ) dol_print_error ( $db );
2015-01-17 19:28:27 +01:00
$object -> fetch_thirdparty ();
2014-03-01 19:45:13 +01:00
2013-04-20 00:10:20 +02:00
// Clean parameters
2015-01-17 19:28:27 +01:00
$date_start = '' ;
$date_end = '' ;
$date_start = dol_mktime ( GETPOST ( 'date_starthour' ), GETPOST ( 'date_startmin' ), GETPOST ( 'date_startsec' ), GETPOST ( 'date_startmonth' ), GETPOST ( 'date_startday' ), GETPOST ( 'date_startyear' ));
$date_end = dol_mktime ( GETPOST ( 'date_endhour' ), GETPOST ( 'date_endmin' ), GETPOST ( 'date_endsec' ), GETPOST ( 'date_endmonth' ), GETPOST ( 'date_endday' ), GETPOST ( 'date_endyear' ));
2017-09-25 00:16:52 +02:00
$description = dol_htmlcleanlastbr ( GETPOST ( 'product_desc' , 'none' ) ? GETPOST ( 'product_desc' , 'none' ) : GETPOST ( 'desc' , 'none' ));
2015-01-17 19:28:27 +01:00
$pu_ht = GETPOST ( 'price_ht' );
$vat_rate = ( GETPOST ( 'tva_tx' ) ? GETPOST ( 'tva_tx' ) : 0 );
2015-01-18 17:13:42 +01:00
$qty = GETPOST ( 'qty' );
2016-12-10 19:54:16 +01:00
$pu_ht_devise = GETPOST ( 'multicurrency_subprice' );
2016-08-10 09:47:25 +02:00
2015-01-17 19:28:27 +01:00
// Define info_bits
2014-02-23 20:10:05 +01:00
$info_bits = 0 ;
2018-01-17 19:45:23 +01:00
if ( preg_match ( '/\*/' , $vat_rate )) $info_bits |= 0x01 ;
2014-03-01 19:45:13 +01:00
2015-05-07 13:35:09 +02:00
// Define vat_rate
2015-01-17 19:28:27 +01:00
$vat_rate = str_replace ( '*' , '' , $vat_rate );
2015-01-18 17:13:42 +01:00
$localtax1_rate = get_localtax ( $vat_rate , 1 , $object -> thirdparty );
$localtax2_rate = get_localtax ( $vat_rate , 2 , $object -> thirdparty );
2015-01-17 19:28:27 +01:00
// Add buying price
$fournprice = price2num ( GETPOST ( 'fournprice' ) ? GETPOST ( 'fournprice' ) : '' );
2015-11-04 17:51:15 +01:00
$buyingprice = price2num ( GETPOST ( 'buying_price' ) != '' ? GETPOST ( 'buying_price' ) : '' ); // If buying_price is '0', we muste keep this value
2016-07-19 07:46:27 +02:00
2015-01-17 19:28:27 +01:00
// Extrafields
$extrafieldsline = new ExtraFields ( $db );
$extralabelsline = $extrafieldsline -> fetch_name_optionals_label ( $object -> table_element_line );
2015-02-28 04:59:27 +01:00
$array_options = $extrafieldsline -> getOptionalsFromPost ( $extralabelsline );
2015-01-17 19:28:27 +01:00
// Unset extrafield
if ( is_array ( $extralabelsline )) {
// Get extra fields
foreach ( $extralabelsline as $key => $value ) {
unset ( $_POST [ " options_ " . $key ]);
}
2013-04-20 00:10:20 +02:00
}
2014-08-05 09:28:58 +02:00
2015-05-07 12:10:27 +02:00
// Define special_code for special lines
$special_code = GETPOST ( 'special_code' );
if ( ! GETPOST ( 'qty' )) $special_code = 3 ;
2015-01-18 18:44:22 +01:00
$line = new FactureLigne ( $db );
$line -> fetch ( GETPOST ( 'lineid' ));
2016-03-12 20:49:38 +01:00
$percent = $line -> get_prev_progress ( $object -> id );
2013-08-12 15:34:09 +02:00
2018-04-05 17:13:45 +02:00
if ( $object -> type == Facture :: TYPE_CREDIT_NOTE && $object -> situation_cycle_ref > 0 )
{
// in case of situation credit note
if ( GETPOST ( 'progress' ) >= 0 )
{
$mesg = $langs -> trans ( " CantBeNullOrPositive " );
setEventMessages ( $mesg , null , 'warnings' );
$error ++ ;
$result = - 1 ;
}
elseif ( GETPOST ( 'progress' ) < $line -> situation_percent ) // TODO : use a modified $line->get_prev_progress($object->id) result
{
$mesg = $langs -> trans ( " CantBeLessThanMinPercent " );
setEventMessages ( $mesg , null , 'warnings' );
$error ++ ;
$result = - 1 ;
}
}
elseif ( GETPOST ( 'progress' ) < $percent )
2015-01-18 18:44:22 +01:00
{
$mesg = '<div class="warning">' . $langs -> trans ( " CantBeLessThanMinPercent " ) . '</div>' ;
setEventMessages ( $mesg , null , 'warnings' );
$error ++ ;
$result = - 1 ;
}
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Check minimum price
$productid = GETPOST ( 'productid' , 'int' );
2015-01-18 18:44:22 +01:00
if ( ! empty ( $productid ))
{
2015-01-17 19:28:27 +01:00
$product = new Product ( $db );
$product -> fetch ( $productid );
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$type = $product -> type ;
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$price_min = $product -> price_min ;
2018-05-23 17:05:08 +02:00
if (( ! empty ( $conf -> global -> PRODUIT_MULTIPRICES ) || ! empty ( $conf -> global -> PRODUIT_CUSTOMER_PRICES_BY_QTY_MULTIPRICES )) && ! empty ( $object -> thirdparty -> price_level ))
2015-01-18 17:13:42 +01:00
$price_min = $product -> multiprices_min [ $object -> thirdparty -> price_level ];
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
$label = (( GETPOST ( 'update_label' ) && GETPOST ( 'product_label' )) ? GETPOST ( 'product_label' ) : '' );
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Check price is not lower than minimum (check is done only for standard or replacement invoices)
2018-11-14 14:59:36 +01:00
if ( $usercanproductignorepricemin && (( $object -> type == Facture :: TYPE_STANDARD || $object -> type == Facture :: TYPE_REPLACEMENT ) && $price_min && ( price2num ( $pu_ht ) * ( 1 - price2num ( GETPOST ( 'remise_percent' )) / 100 ) < price2num ( $price_min )))) {
2015-11-15 07:47:35 +01:00
setEventMessages ( $langs -> trans ( " CantBeLessThanMinPrice " , price ( price2num ( $price_min , 'MU' ), 0 , $langs , 0 , 0 , - 1 , $conf -> currency )), null , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-01-17 19:28:27 +01:00
}
2014-02-23 20:10:05 +01:00
} else {
$type = GETPOST ( 'type' );
2015-01-17 19:28:27 +01:00
$label = ( GETPOST ( 'product_label' ) ? GETPOST ( 'product_label' ) : '' );
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
// Check parameters
if ( GETPOST ( 'type' ) < 0 ) {
2015-10-17 16:18:33 +02:00
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " Type " )), null , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
2015-01-17 19:28:27 +01:00
}
}
2015-01-18 17:13:42 +01:00
if ( $qty < 0 ) {
$langs -> load ( " errors " );
2015-11-15 07:47:35 +01:00
setEventMessages ( $langs -> trans ( 'ErrorQtyForCustomerInvoiceCantBeNegative' ), null , 'errors' );
2018-09-04 10:37:29 +02:00
$error ++ ;
}
if ( empty ( $productid ) && (( $pu_ht < 0 && empty ( $conf -> global -> FACTURE_ENABLE_NEGATIVE_LINES )) || $pu_ht == '' ) && $pu_ht_devise == '' ) // Unit price can be 0 but not ''
{
if ( $pu_ht < 0 && empty ( $conf -> global -> FACTURE_ENABLE_NEGATIVE_LINES ))
{
$langs -> load ( " errors " );
setEventMessages ( $langs -> trans ( " ErrorFieldCantBeNegativeOnInvoice " , $langs -> transnoentitiesnoconv ( " UnitPriceHT " )), null , 'errors' );
$error ++ ;
}
else
{
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " UnitPriceHT " )), null , 'errors' );
$error ++ ;
}
2015-01-18 17:13:42 +01:00
}
2014-03-01 19:45:13 +01:00
2018-09-04 10:37:29 +02:00
2015-01-17 19:28:27 +01:00
// Update line
if ( ! $error ) {
2018-11-14 14:59:36 +01:00
if ( empty ( $usercancreatemargin ))
2016-12-15 12:01:46 +01:00
{
foreach ( $object -> lines as & $line )
{
if ( $line -> id == GETPOST ( 'lineid' ))
{
$fournprice = $line -> fk_fournprice ;
$buyingprice = $line -> pa_ht ;
break ;
}
}
}
2016-12-24 21:39:40 +01:00
2015-02-26 14:15:33 +01:00
$result = $object -> updateline ( GETPOST ( 'lineid' ), $description , $pu_ht , $qty , GETPOST ( 'remise_percent' ),
$date_start , $date_end , $vat_rate , $localtax1_rate , $localtax2_rate , 'HT' , $info_bits , $type ,
2015-05-07 13:35:09 +02:00
GETPOST ( 'fk_parent_line' ), 0 , $fournprice , $buyingprice , $label , $special_code , $array_options , GETPOST ( 'progress' ),
2016-12-10 19:54:16 +01:00
$_POST [ 'units' ], $pu_ht_devise );
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
if ( $result >= 0 ) {
2014-02-23 20:10:05 +01:00
if ( empty ( $conf -> global -> MAIN_DISABLE_PDF_AUTOUPDATE )) {
2013-04-20 00:10:20 +02:00
// Define output language
$outputlangs = $langs ;
2014-10-27 19:37:30 +01:00
$newlang = '' ;
2017-06-27 17:27:01 +02:00
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang ) && GETPOST ( 'lang_id' , 'aZ09' ))
$newlang = GETPOST ( 'lang_id' , 'aZ09' );
2015-01-17 19:28:27 +01:00
if ( $conf -> global -> MAIN_MULTILANGS && empty ( $newlang ))
2014-08-01 16:17:31 +02:00
$newlang = $object -> thirdparty -> default_lang ;
2014-02-23 20:10:05 +01:00
if ( ! empty ( $newlang )) {
$outputlangs = new Translate ( " " , $conf );
2013-04-20 00:10:20 +02:00
$outputlangs -> setDefaultLang ( $newlang );
2018-02-08 12:53:26 +01:00
$outputlangs -> load ( 'products' );
2013-04-20 00:10:20 +02:00
}
2014-12-25 23:08:07 +01:00
2014-02-23 20:10:05 +01:00
$ret = $object -> fetch ( $id ); // Reload to get new records
2015-01-18 17:13:42 +01:00
$object -> generateDocument ( $object -> modelpdf , $outputlangs , $hidedetails , $hidedesc , $hideref );
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2014-03-20 00:05:20 +01:00
unset ( $_POST [ 'qty' ]);
unset ( $_POST [ 'type' ]);
2015-01-17 19:28:27 +01:00
unset ( $_POST [ 'productid' ]);
2014-03-20 00:05:20 +01:00
unset ( $_POST [ 'remise_percent' ]);
unset ( $_POST [ 'price_ht' ]);
2016-04-12 14:10:27 +02:00
unset ( $_POST [ 'multicurrency_price_ht' ]);
2014-03-20 00:05:20 +01:00
unset ( $_POST [ 'price_ttc' ]);
unset ( $_POST [ 'tva_tx' ]);
unset ( $_POST [ 'product_ref' ]);
unset ( $_POST [ 'product_label' ]);
unset ( $_POST [ 'product_desc' ]);
unset ( $_POST [ 'fournprice' ]);
unset ( $_POST [ 'buying_price' ]);
unset ( $_POST [ 'np_marginRate' ]);
unset ( $_POST [ 'np_markRate' ]);
2015-01-18 18:44:22 +01:00
2014-03-20 00:05:20 +01:00
unset ( $_POST [ 'dp_desc' ]);
unset ( $_POST [ 'idprod' ]);
2015-02-26 14:15:33 +01:00
unset ( $_POST [ 'units' ]);
2014-05-05 17:59:43 +02:00
2017-10-16 08:47:05 +02:00
unset ( $_POST [ 'date_starthour' ]);
unset ( $_POST [ 'date_startmin' ]);
unset ( $_POST [ 'date_startsec' ]);
unset ( $_POST [ 'date_startday' ]);
unset ( $_POST [ 'date_startmonth' ]);
unset ( $_POST [ 'date_startyear' ]);
unset ( $_POST [ 'date_endhour' ]);
unset ( $_POST [ 'date_endmin' ]);
unset ( $_POST [ 'date_endsec' ]);
unset ( $_POST [ 'date_endday' ]);
unset ( $_POST [ 'date_endmonth' ]);
unset ( $_POST [ 'date_endyear' ]);
2014-11-14 16:43:49 +01:00
unset ( $_POST [ 'situations' ]);
unset ( $_POST [ 'progress' ]);
2014-02-23 20:10:05 +01:00
} else {
2015-11-15 07:47:35 +01:00
setEventMessages ( $object -> error , $object -> errors , 'errors' );
2013-04-20 00:10:20 +02:00
}
}
}
2014-03-01 19:45:13 +01:00
2018-11-14 14:59:36 +01:00
else if ( $action == 'updatealllines' && $usercancreate && $_POST [ 'all_percent' ] == $langs -> trans ( 'Modifier' ))
2015-01-18 18:44:22 +01:00
{
if ( ! $object -> fetch ( $id ) > 0 ) dol_print_error ( $db );
if ( ! is_null ( GETPOST ( 'all_progress' )) && GETPOST ( 'all_progress' ) != " " )
{
foreach ( $object -> lines as $line )
{
2016-03-12 20:49:38 +01:00
$percent = $line -> get_prev_progress ( $object -> id );
2015-01-18 18:44:22 +01:00
if ( GETPOST ( 'all_progress' ) < $percent ) {
$mesg = '<div class="warning">' . $langs -> trans ( " CantBeLessThanMinPercent " ) . '</div>' ;
$result = - 1 ;
} else
$object -> update_percent ( $line , $_POST [ 'all_progress' ]);
}
2013-04-20 00:10:20 +02:00
}
}
2014-03-01 19:45:13 +01:00
2018-11-14 14:59:36 +01:00
else if ( $action == 'updateline' && $usercancreate && $_POST [ 'cancel' ] == $langs -> trans ( 'Cancel' )) {
2015-01-17 19:28:27 +01:00
header ( 'Location: ' . $_SERVER [ " PHP_SELF " ] . '?facid=' . $id ); // Pour reaffichage de la fiche en cours d'edition
exit ();
2013-06-10 16:05:41 +02:00
}
2018-02-22 16:55:41 +01:00
2018-05-23 08:16:24 +02:00
// Outing situation invoice from cycle
2018-11-14 14:59:36 +01:00
elseif ( $action == 'confirm_situationout' && $confirm == 'yes' && $usercancreate )
2018-04-03 17:34:20 +02:00
{
2018-05-17 09:01:49 +02:00
$object -> fetch ( $id , '' , '' , '' , true );
2018-05-23 08:16:24 +02:00
2018-04-03 17:34:20 +02:00
if ( $object -> statut == Facture :: STATUS_VALIDATED
2018-04-05 11:25:11 +02:00
&& $object -> type == Facture :: TYPE_SITUATION
2018-11-14 14:59:36 +01:00
&& $usercancreate
2018-04-03 17:34:20 +02:00
&& ! $objectidnext
&& $object -> is_last_in_cycle ()
2018-11-14 14:59:36 +01:00
&& $usercanunvalidate
2018-05-23 08:16:24 +02:00
)
2018-04-03 17:34:20 +02:00
{
$outingError = 0 ;
$newCycle = $object -> newCycle (); // we need to keep the "situation behavior" so we place it on a new situation cycle
if ( $newCycle > 1 )
{
2018-05-23 08:16:24 +02:00
// Search credit notes
2018-04-03 17:34:20 +02:00
$lastCycle = $object -> situation_cycle_ref ;
2018-04-05 10:48:20 +02:00
$lastSituationCounter = $object -> situation_counter ;
$linkedCreditNotesList = array ();
2018-05-23 08:16:24 +02:00
2018-04-05 10:48:20 +02:00
if ( count ( $object -> tab_next_situation_invoice ) > 0 ) {
foreach ( $object -> tab_next_situation_invoice as $next_invoice ) {
2018-05-23 08:16:24 +02:00
if ( $next_invoice -> type == Facture :: TYPE_CREDIT_NOTE
2018-04-05 10:48:20 +02:00
&& $next_invoice -> situation_counter == $object -> situation_counter
&& $next_invoice -> fk_facture_source == $object -> id
)
{
$linkedCreditNotesList [] = $next_invoice -> id ;
}
}
}
2018-05-23 08:16:24 +02:00
2018-04-03 17:34:20 +02:00
$object -> situation_cycle_ref = $newCycle ;
$object -> situation_counter = 1 ;
2018-04-05 10:48:20 +02:00
$object -> situation_final = 0 ;
2018-04-03 17:34:20 +02:00
if ( $object -> update ( $user ) > 0 )
{
2018-04-05 10:48:20 +02:00
$errors = 0 ;
if ( count ( $linkedCreditNotesList ) > 0 )
{
// now, credit note must follow
$sql = 'UPDATE ' . MAIN_DB_PREFIX . 'facture ' ;
$sql .= ' SET situation_cycle_ref=' . $newCycle ;
$sql .= ' , situation_final=0' ;
$sql .= ' , situation_counter=' . $object -> situation_counter ;
$sql .= ' WHERE rowid IN (' . implode ( ',' , $linkedCreditNotesList ) . ')' ;
2018-05-23 08:16:24 +02:00
2018-04-05 10:48:20 +02:00
$resql = $db -> query ( $sql );
if ( ! $resql ) $errors ++ ;
2018-05-23 08:16:24 +02:00
2018-04-05 11:25:11 +02:00
// Change each progression persent on each lines
foreach ( $object -> lines as $line )
{
2018-05-23 08:16:24 +02:00
2018-04-05 11:25:11 +02:00
// no traitement for special product
if ( $line -> product_type == 9 ) continue ;
2018-05-23 08:16:24 +02:00
2018-04-05 11:25:11 +02:00
if ( ! empty ( $object -> tab_previous_situation_invoice ))
{
// search the last invoice in cycle
$lineIndex = count ( $object -> tab_previous_situation_invoice ) - 1 ;
$searchPreviousInvoice = true ;
while ( $searchPreviousInvoice )
{
if ( $object -> tab_previous_situation_invoice [ $lineIndex ] -> type == Facture :: TYPE_SITUATION || $lineIndex < 1 )
{
$searchPreviousInvoice = false ; // find, exit;
break ;
}
else
{
$lineIndex -- ; // go to previous invoice in cycle
}
}
2018-05-23 08:16:24 +02:00
2018-04-05 11:25:11 +02:00
$maxPrevSituationPercent = 0 ;
foreach ( $object -> tab_previous_situation_invoice [ $lineIndex ] -> lines as $prevLine )
{
if ( $prevLine -> id == $line -> fk_prev_id )
{
$maxPrevSituationPercent = max ( $maxPrevSituationPercent , $prevLine -> situation_percent );
}
}
2018-05-23 08:16:24 +02:00
2018-04-05 11:25:11 +02:00
$line -> situation_percent = $line -> situation_percent - $maxPrevSituationPercent ;
2018-05-23 08:16:24 +02:00
2018-04-05 11:25:11 +02:00
if ( $line -> update () < 0 ) $errors ++ ;
}
}
2018-04-05 10:48:20 +02:00
}
2018-05-23 08:16:24 +02:00
2018-04-05 10:48:20 +02:00
if ( ! $errors )
2018-04-03 17:34:20 +02:00
{
2018-05-23 08:16:24 +02:00
setEventMessages ( $langs -> trans ( 'Updated' ), '' , 'mesgs' );
2018-04-03 17:34:20 +02:00
header ( " Location: " . $_SERVER [ 'PHP_SELF' ] . " ?id= " . $id );
}
else
{
setEventMessages ( $langs -> trans ( 'ErrorOutingSituationInvoiceCreditNote' ), array (), 'errors' );
}
}
2018-05-23 08:16:24 +02:00
else
2018-04-03 17:34:20 +02:00
{
setEventMessages ( $langs -> trans ( 'ErrorOutingSituationInvoiceOnUpdate' ), array (), 'errors' );
}
}
else
{
setEventMessages ( $langs -> trans ( 'ErrorFindNextSituationInvoice' ), array (), 'errors' );
}
}
}
2018-02-22 16:55:41 +01:00
2018-02-22 15:19:20 +01:00
// add lines from objectlinked
2018-02-22 16:55:41 +01:00
elseif ( $action == 'import_lines_from_object'
2018-11-14 14:59:36 +01:00
&& $usercancreate
2018-02-22 16:55:41 +01:00
&& $object -> statut == Facture :: STATUS_DRAFT
&& ( $object -> type == Facture :: TYPE_STANDARD || $object -> type == Facture :: TYPE_REPLACEMENT || $object -> type == Facture :: TYPE_DEPOSIT || $object -> type == Facture :: TYPE_PROFORMA || $object -> type == Facture :: TYPE_SITUATION ))
2018-02-22 15:19:20 +01:00
{
2018-02-22 16:55:41 +01:00
$fromElement = GETPOST ( 'fromelement' );
2018-02-23 12:12:36 +01:00
$fromElementid = GETPOST ( 'fromelementid' );
2018-02-22 16:55:41 +01:00
$importLines = GETPOST ( 'line_checkbox' );
2018-04-10 12:03:01 +02:00
2018-02-22 16:55:41 +01:00
if ( ! empty ( $importLines ) && is_array ( $importLines ) && ! empty ( $fromElement ) && ctype_alpha ( $fromElement ) && ! empty ( $fromElementid ))
{
if ( $fromElement == 'commande' )
{
2018-05-10 21:06:18 +02:00
dol_include_once ( '/' . $fromElement . '/class/' . $fromElement . '.class.php' );
2018-02-22 16:55:41 +01:00
$lineClassName = 'OrderLine' ;
}
2018-05-10 21:06:18 +02:00
elseif ( $fromElement == 'propal' )
{
dol_include_once ( '/comm/' . $fromElement . '/class/' . $fromElement . '.class.php' );
$lineClassName = 'PropaleLigne' ;
}
2018-02-22 16:55:41 +01:00
$nextRang = count ( $object -> lines ) + 1 ;
$importCount = 0 ;
$error = 0 ;
foreach ( $importLines as $lineId )
{
2018-02-23 12:12:36 +01:00
$lineId = intval ( $lineId );
2018-02-22 16:55:41 +01:00
$originLine = new $lineClassName ( $db );
2018-02-23 12:12:36 +01:00
if ( intval ( $fromElementid ) > 0 && $originLine -> fetch ( $lineId ) > 0 )
2018-02-22 16:55:41 +01:00
{
2018-02-23 12:12:36 +01:00
$originLine -> fetch_optionals ( $lineId );
2018-02-22 16:55:41 +01:00
$desc = $originLine -> desc ;
$pu_ht = $originLine -> subprice ;
$qty = $originLine -> qty ;
$txtva = $originLine -> tva_tx ;
$txlocaltax1 = $originLine -> localtax1_tx ;
$txlocaltax2 = $originLine -> localtax2_tx ;
$fk_product = $originLine -> fk_product ;
$remise_percent = $originLine -> remise_percent ;
$date_start = $originLine -> date_start ;
$date_end = $originLine -> date_end ;
$ventil = 0 ;
$info_bits = $originLine -> info_bits ;
$fk_remise_except = $originLine -> fk_remise_except ;
$price_base_type = 'HT' ;
$pu_ttc = 0 ;
2018-02-23 12:12:36 +01:00
$type = $originLine -> product_type ;
2018-02-22 16:55:41 +01:00
$rang = $nextRang ++ ;
$special_code = $originLine -> special_code ;
$origin = $originLine -> element ;
$origin_id = $originLine -> id ;
$fk_parent_line = 0 ;
$fk_fournprice = $originLine -> fk_fournprice ;
$pa_ht = $originLine -> pa_ht ;
$label = $originLine -> label ;
$array_options = $originLine -> array_options ;
$situation_percent = 100 ;
$fk_prev_id = '' ;
$fk_unit = $originLine -> fk_unit ;
$pu_ht_devise = $originLine -> multicurrency_subprice ;
2018-04-10 12:03:01 +02:00
2018-02-22 16:55:41 +01:00
$res = $object -> addline ( $desc , $pu_ht , $qty , $txtva , $txlocaltax1 , $txlocaltax2 , $fk_product , $remise_percent , $date_start , $date_end , $ventil , $info_bits , $fk_remise_except , $price_base_type , $pu_ttc , $type , $rang , $special_code , $origin , $origin_id , $fk_parent_line , $fk_fournprice , $pa_ht , $label , $array_options , $situation_percent , $fk_prev_id , $fk_unit , $pu_ht_devise );
2018-05-23 08:16:24 +02:00
2018-02-22 16:55:41 +01:00
if ( $res > 0 ){
$importCount ++ ;
} else {
$error ++ ;
}
}
2018-04-10 12:03:01 +02:00
else {
$error ++ ;
2018-02-22 16:55:41 +01:00
}
}
2018-04-10 12:03:01 +02:00
2018-02-22 16:55:41 +01:00
if ( $error )
{
2018-07-24 18:28:56 +02:00
setEventMessages ( $langs -> trans ( 'ErrorsOnXLines' , $error ), null , 'errors' );
2018-02-22 16:55:41 +01:00
}
}
2018-02-22 15:19:20 +01:00
}
2018-04-10 12:03:01 +02:00
2017-09-17 15:38:50 +02:00
// Actions when printing a doc from card
include DOL_DOCUMENT_ROOT . '/core/actions_printing.inc.php' ;
2013-09-23 12:31:10 +02:00
2015-01-18 17:13:42 +01:00
// Actions to send emails
if ( empty ( $id )) $id = $facid ;
$trigger_name = 'BILL_SENTBYMAIL' ;
$paramname = 'id' ;
2017-09-17 15:38:50 +02:00
$autocopy = 'MAIN_MAIL_AUTOCOPY_INVOICE_TO' ;
2016-10-03 00:38:28 +02:00
$trackid = 'inv' . $object -> id ;
2015-01-18 17:13:42 +01:00
include DOL_DOCUMENT_ROOT . '/core/actions_sendmails.inc.php' ;
2010-01-13 11:30:33 +01:00
2017-10-16 08:47:05 +02:00
// Actions to build doc
$upload_dir = $conf -> facture -> dir_output ;
2018-11-14 14:59:36 +01:00
$permissioncreate = $usercancreate ;
2017-10-16 08:47:05 +02:00
include DOL_DOCUMENT_ROOT . '/core/actions_builddoc.inc.php' ;
2016-08-10 09:47:25 +02:00
2014-03-01 19:45:13 +01:00
2016-06-24 12:50:50 +02:00
if ( $action == 'update_extras' ) {
2018-02-23 16:11:00 +01:00
$object -> oldcopy = dol_clone ( $object );
2015-09-12 17:28:32 +02:00
// Fill array 'array_options' with data from add form
$extralabels = $extrafields -> fetch_name_optionals_label ( $object -> table_element );
2018-02-23 16:11:00 +01:00
$ret = $extrafields -> setOptionalsFromPost ( $extralabels , $object , GETPOST ( 'attribute' , 'none' ));
2015-09-12 17:28:32 +02:00
if ( $ret < 0 ) $error ++ ;
2018-04-10 12:03:01 +02:00
if ( ! $error )
{
// Actions on extra fields
$result = $object -> insertExtraFields ( 'BILL_MODIFY' );
if ( $result < 0 )
{
setEventMessages ( $object -> error , $object -> errors , 'errors' );
$error ++ ;
}
2015-09-12 17:28:32 +02:00
}
if ( $error )
$action = 'edit_extras' ;
2013-04-20 17:10:03 +02:00
}
2018-11-14 14:59:36 +01:00
if ( ! empty ( $conf -> global -> MAIN_DISABLE_CONTACTS_TAB ) && $usercancreate ) {
2015-09-12 17:28:32 +02:00
if ( $action == 'addcontact' ) {
2015-01-17 19:28:27 +01:00
$result = $object -> fetch ( $id );
2014-03-01 19:45:13 +01:00
2015-01-17 19:28:27 +01:00
if ( $result > 0 && $id > 0 ) {
$contactid = ( GETPOST ( 'userid' ) ? GETPOST ( 'userid' ) : GETPOST ( 'contactid' ));
$result = $object -> add_contact ( $contactid , $_POST [ " type " ], $_POST [ " source " ]);
}
2014-03-01 19:45:13 +01:00
2015-09-12 17:28:32 +02:00
if ( $result >= 0 ) {
header ( " Location: " . $_SERVER [ 'PHP_SELF' ] . " ?id= " . $object -> id );
exit ();
2014-02-23 20:10:05 +01:00
} else {
2015-09-12 17:28:32 +02:00
if ( $object -> error == 'DB_ERROR_RECORD_ALREADY_EXISTS' ) {
$langs -> load ( " errors " );
2015-11-15 07:47:35 +01:00
setEventMessages ( $langs -> trans ( " ErrorThisContactIsAlreadyDefinedAsThisType " ), null , 'errors' );
2015-09-12 17:28:32 +02:00
} else {
2015-11-15 07:47:35 +01:00
setEventMessages ( $object -> error , $object -> errors , 'errors' );
2015-09-12 17:28:32 +02:00
}
2013-04-20 17:10:03 +02:00
}
2015-09-12 17:28:32 +02:00
} // bascule du statut d'un contact
elseif ( $action == 'swapstatut' ) {
if ( $object -> fetch ( $id )) {
$result = $object -> swapContactStatus ( GETPOST ( 'ligne' ));
} else {
dol_print_error ( $db );
2013-04-20 17:10:03 +02:00
}
2015-09-12 17:28:32 +02:00
} // Efface un contact
elseif ( $action == 'deletecontact' ) {
$object -> fetch ( $id );
$result = $object -> delete_contact ( $lineid );
2013-04-20 00:10:20 +02:00
2015-09-12 17:28:32 +02:00
if ( $result >= 0 ) {
header ( " Location: " . $_SERVER [ 'PHP_SELF' ] . " ?id= " . $object -> id );
exit ();
} else {
dol_print_error ( $db );
2015-01-18 18:44:22 +01:00
}
}
2015-10-15 17:26:16 +02:00
if ( $error )
$action = 'edit_extras' ;
2014-02-23 20:10:05 +01:00
}
2013-04-20 17:10:03 +02:00
}
2008-08-12 20:20:18 +02:00
2014-03-19 23:49:07 +01:00
2013-04-20 17:10:03 +02:00
/*
* View
2014-03-19 22:30:25 +01:00
*/
2013-03-24 00:35:40 +01:00
2013-04-20 17:10:03 +02:00
$form = new Form ( $db );
2014-02-23 20:10:05 +01:00
$formother = new FormOther ( $db );
2013-04-20 17:10:03 +02:00
$formfile = new FormFile ( $db );
2015-10-03 19:05:13 +02:00
$formmargin = new FormMargin ( $db );
2016-02-07 14:22:52 +01:00
$paymentstatic = new Paiement ( $db );
2014-02-23 20:10:05 +01:00
$bankaccountstatic = new Account ( $db );
2015-06-03 11:55:39 +02:00
if ( ! empty ( $conf -> projet -> enabled )) { $formproject = new FormProjets ( $db ); }
2014-02-23 20:10:05 +01:00
$now = dol_now ();
2013-03-24 00:35:40 +01:00
2016-08-31 06:27:35 +02:00
$title = $langs -> trans ( 'InvoiceCustomer' ) . " - " . $langs -> trans ( 'Card' );
$helpurl = " EN:Customers_Invoices|FR:Factures_Clients|ES:Facturas_a_clientes " ;
llxHeader ( '' , $title , $helpurl );
2010-07-25 23:23:57 +02:00
2014-08-07 14:57:08 +02:00
2016-02-29 15:43:00 +01:00
// Mode creation
2014-03-19 23:49:07 +01:00
2014-03-01 19:45:13 +01:00
if ( $action == 'create' )
{
2014-02-23 20:10:05 +01:00
$facturestatic = new Facture ( $db );
$extralabels = $extrafields -> fetch_name_optionals_label ( $facturestatic -> table_element );
2014-03-01 19:45:13 +01:00
2015-09-24 18:33:48 +02:00
print load_fiche_titre ( $langs -> trans ( 'NewBill' ));
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
$soc = new Societe ( $db );
2014-02-23 20:10:05 +01:00
if ( $socid > 0 )
$res = $soc -> fetch ( $socid );
2014-03-01 19:45:13 +01:00
2016-01-23 16:01:55 +01:00
$currency_code = $conf -> currency ;
2016-08-10 09:47:25 +02:00
2014-06-28 19:47:51 +02:00
// Load objectsrc
2015-11-07 13:21:03 +01:00
$remise_absolue = 0 ;
2014-03-20 00:05:20 +01:00
if ( ! empty ( $origin ) && ! empty ( $originid ))
{
2013-04-20 17:10:03 +02:00
// Parse element/subelement (ex: project_task)
$element = $subelement = $origin ;
2014-02-23 20:10:05 +01:00
if ( preg_match ( '/^([^_]+)_([^_]+)/i' , $origin , $regs )) {
$element = $regs [ 1 ];
$subelement = $regs [ 2 ];
}
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
if ( $element == 'project' ) {
$projectid = $originid ;
2016-03-11 15:42:14 +01:00
2015-11-13 11:43:29 +01:00
if ( ! $cond_reglement_id ) {
$cond_reglement_id = $soc -> cond_reglement_id ;
}
if ( ! $mode_reglement_id ) {
$mode_reglement_id = $soc -> mode_reglement_id ;
}
if ( ! $remise_percent ) {
$remise_percent = $soc -> remise_percent ;
}
if ( ! $dateinvoice ) {
// Do not set 0 here (0 for a date is 1970)
$dateinvoice = ( empty ( $dateinvoice ) ? ( empty ( $conf -> global -> MAIN_AUTOFILL_DATE ) ? - 1 : '' ) : $dateinvoice );
2016-03-11 15:42:14 +01:00
}
2014-02-23 20:10:05 +01:00
} else {
2013-04-20 17:10:03 +02:00
// For compatibility
2014-02-23 20:10:05 +01:00
if ( $element == 'order' || $element == 'commande' ) {
2013-04-20 17:10:03 +02:00
$element = $subelement = 'commande' ;
}
2014-02-23 20:10:05 +01:00
if ( $element == 'propal' ) {
$element = 'comm/propal' ;
$subelement = 'propal' ;
2013-04-20 17:10:03 +02:00
}
if ( $element == 'contract' ) {
$element = $subelement = 'contrat' ;
}
if ( $element == 'shipping' ) {
$element = $subelement = 'expedition' ;
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
dol_include_once ( '/' . $element . '/class/' . $subelement . '.class.php' );
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
$classname = ucfirst ( $subelement );
$objectsrc = new $classname ( $db );
$objectsrc -> fetch ( $originid );
2014-02-23 20:10:05 +01:00
if ( empty ( $objectsrc -> lines ) && method_exists ( $objectsrc , 'fetch_lines' ))
$objectsrc -> fetch_lines ();
2013-04-20 17:10:03 +02:00
$objectsrc -> fetch_thirdparty ();
2014-03-01 19:45:13 +01:00
2015-10-19 15:38:28 +02:00
$projectid = ( ! empty ( $projectid ) ? $projectid : $objectsrc -> fk_project );
2016-04-01 17:32:58 +02:00
$ref_client = ( ! empty ( $objectsrc -> ref_client ) ? $objectsrc -> ref_client : ( ! empty ( $objectsrc -> ref_customer ) ? $objectsrc -> ref_customer : '' ));
2014-02-23 20:10:05 +01:00
$ref_int = ( ! empty ( $objectsrc -> ref_int ) ? $objectsrc -> ref_int : '' );
2014-03-01 19:45:13 +01:00
2014-12-28 12:34:21 +01:00
// only if socid not filled else it's allready done upper
2014-12-14 18:03:30 +01:00
if ( empty ( $socid ))
$soc = $objectsrc -> thirdparty ;
2014-05-29 19:20:48 +02:00
2016-09-14 11:17:44 +02:00
$cond_reglement_id = ( ! empty ( $objectsrc -> cond_reglement_id ) ? $objectsrc -> cond_reglement_id : ( ! empty ( $soc -> cond_reglement_id ) ? $soc -> cond_reglement_id : 0 ));
2013-04-20 17:10:03 +02:00
$mode_reglement_id = ( ! empty ( $objectsrc -> mode_reglement_id ) ? $objectsrc -> mode_reglement_id : ( ! empty ( $soc -> mode_reglement_id ) ? $soc -> mode_reglement_id : 0 ));
2017-10-16 08:47:05 +02:00
$fk_account = ( ! empty ( $objectsrc -> fk_account ) ? $objectsrc -> fk_account : ( ! empty ( $soc -> fk_account ) ? $soc -> fk_account : 0 ));
2013-04-20 17:10:03 +02:00
$remise_percent = ( ! empty ( $objectsrc -> remise_percent ) ? $objectsrc -> remise_percent : ( ! empty ( $soc -> remise_percent ) ? $soc -> remise_percent : 0 ));
$remise_absolue = ( ! empty ( $objectsrc -> remise_absolue ) ? $objectsrc -> remise_absolue : ( ! empty ( $soc -> remise_absolue ) ? $soc -> remise_absolue : 0 ));
2014-06-21 15:35:30 +02:00
$dateinvoice = ( empty ( $dateinvoice ) ? ( empty ( $conf -> global -> MAIN_AUTOFILL_DATE ) ? - 1 : '' ) : $dateinvoice );
2014-03-01 19:45:13 +01:00
2016-01-23 16:01:55 +01:00
if ( ! empty ( $conf -> multicurrency -> enabled ))
{
if ( ! empty ( $objectsrc -> multicurrency_code )) $currency_code = $objectsrc -> multicurrency_code ;
2016-08-10 09:47:25 +02:00
if ( ! empty ( $conf -> global -> MULTICURRENCY_USE_ORIGIN_TX ) && ! empty ( $objectsrc -> multicurrency_tx )) $currency_tx = $objectsrc -> multicurrency_tx ;
2016-01-23 16:01:55 +01:00
}
2016-08-10 09:47:25 +02:00
2014-02-23 20:10:05 +01:00
// Replicate extrafields
2013-08-30 14:38:04 +02:00
$objectsrc -> fetch_optionals ( $originid );
2014-02-23 20:10:05 +01:00
$object -> array_options = $objectsrc -> array_options ;
}
2014-04-10 19:47:52 +02:00
}
2013-04-20 17:10:03 +02:00
else
2014-04-10 19:47:52 +02:00
{
2013-04-20 17:10:03 +02:00
$cond_reglement_id = $soc -> cond_reglement_id ;
$mode_reglement_id = $soc -> mode_reglement_id ;
2014-12-14 18:03:30 +01:00
$fk_account = $soc -> fk_account ;
2013-04-20 17:10:03 +02:00
$remise_percent = $soc -> remise_percent ;
$remise_absolue = 0 ;
2014-06-25 20:22:25 +02:00
$dateinvoice = ( empty ( $dateinvoice ) ? ( empty ( $conf -> global -> MAIN_AUTOFILL_DATE ) ? - 1 : '' ) : $dateinvoice ); // Do not set 0 here (0 for a date is 1970)
2016-08-10 09:47:25 +02:00
2016-01-23 16:01:55 +01:00
if ( ! empty ( $conf -> multicurrency -> enabled ) && ! empty ( $soc -> multicurrency_code )) $currency_code = $soc -> multicurrency_code ;
2014-02-23 20:10:05 +01:00
}
2017-06-07 16:44:04 +02:00
2016-09-19 16:27:01 +02:00
if ( ! empty ( $soc -> id )) $absolute_discount = $soc -> getAvailableDiscounts ();
$note_public = $object -> getDefaultCreateValueFor ( 'note_public' , ( is_object ( $objectsrc ) ? $objectsrc -> note_public : null ));
$note_private = $object -> getDefaultCreateValueFor ( 'note_private' , (( ! empty ( $origin ) && ! empty ( $originid ) && is_object ( $objectsrc )) ? $objectsrc -> note_private : null ));
2017-06-07 16:44:04 +02:00
2013-04-20 17:10:03 +02:00
if ( ! empty ( $conf -> use_javascript_ajax ))
2014-03-26 16:02:22 +01:00
{
require_once DOL_DOCUMENT_ROOT . '/core/lib/ajax.lib.php' ;
2014-03-01 20:02:35 +01:00
print ajax_combobox ( 'fac_replacement' );
2013-04-20 17:10:03 +02:00
print ajax_combobox ( 'fac_avoir' );
2014-11-14 16:43:49 +01:00
print ajax_combobox ( 'situations' );
2013-04-20 17:10:03 +02:00
}
2014-03-01 19:45:13 +01:00
2016-03-03 10:42:49 +01:00
if ( $origin == 'contrat' )
{
2017-10-16 08:47:05 +02:00
$langs -> load ( " admin " );
$text = $langs -> trans ( " ToCreateARecurringInvoice " );
$text .= ' ' . $langs -> trans ( " ToCreateARecurringInvoiceGene " , $langs -> transnoentitiesnoconv ( " MenuFinancial " ), $langs -> transnoentitiesnoconv ( " BillsCustomers " ), $langs -> transnoentitiesnoconv ( " ListOfTemplates " ));
if ( empty ( $conf -> global -> INVOICE_DISABLE_AUTOMATIC_RECURRING_INVOICE ))
{
$text .= ' ' . $langs -> trans ( " ToCreateARecurringInvoiceGeneAuto " , $langs -> transnoentitiesnoconv ( 'Module2300Name' ));
}
print info_admin ( $text , 0 , 0 , 0 ) . '<br>' ;
2016-03-03 10:42:49 +01:00
}
2016-08-10 09:47:25 +02:00
2014-05-12 12:10:52 +02:00
print '<form name="add" action="' . $_SERVER [ " PHP_SELF " ] . '" method="POST">' ;
2014-02-23 20:10:05 +01:00
print '<input type="hidden" name="token" value="' . $_SESSION [ 'newtoken' ] . '">' ;
2013-04-20 17:10:03 +02:00
print '<input type="hidden" name="action" value="add">' ;
2014-03-26 16:02:22 +01:00
if ( $soc -> id > 0 ) print '<input type="hidden" name="socid" value="' . $soc -> id . '">' . " \n " ;
2018-12-02 14:31:45 +01:00
print '<input name="ref" type="hidden" value="provisoire">' ;
2014-02-23 20:10:05 +01:00
print '<input name="ref_client" type="hidden" value="' . $ref_client . '">' ;
print '<input name="ref_int" type="hidden" value="' . $ref_int . '">' ;
print '<input type="hidden" name="origin" value="' . $origin . '">' ;
print '<input type="hidden" name="originid" value="' . $originid . '">' ;
2016-01-23 16:01:55 +01:00
if ( ! empty ( $currency_tx )) print '<input type="hidden" name="originmulticurrency_tx" value="' . $currency_tx . '">' ;
2016-08-10 09:47:25 +02:00
2015-05-13 17:53:25 +02:00
dol_fiche_head ( '' );
2015-05-19 00:01:30 +02:00
2013-04-20 17:10:03 +02:00
print '<table class="border" width="100%">' ;
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
// Ref
2016-04-01 16:15:07 +02:00
print '<tr><td class="titlefieldcreate fieldrequired">' . $langs -> trans ( 'Ref' ) . '</td><td colspan="2">' . $langs -> trans ( 'Draft' ) . '</td></tr>' ;
2014-03-01 19:45:13 +01:00
2013-09-21 10:53:46 +02:00
// Thirdparty
2014-02-23 20:10:05 +01:00
print '<td class="fieldrequired">' . $langs -> trans ( 'Customer' ) . '</td>' ;
2017-08-28 18:37:16 +02:00
if ( $soc -> id > 0 && ! GETPOST ( 'fac_rec' , 'alpha' ))
2014-03-19 23:49:07 +01:00
{
2013-08-06 23:50:12 +02:00
print '<td colspan="2">' ;
print $soc -> getNomUrl ( 1 );
2014-02-23 20:10:05 +01:00
print '<input type="hidden" name="socid" value="' . $soc -> id . '">' ;
2013-11-16 14:26:42 +01:00
// Outstanding Bill
2015-04-18 19:08:01 +02:00
$outstandingBills = $soc -> get_OutstandingBill ();
2014-02-23 20:10:05 +01:00
print ' (' . $langs -> trans ( 'CurrentOutstandingBill' ) . ': ' ;
2015-04-18 19:08:01 +02:00
print price ( $outstandingBills , '' , $langs , 0 , 0 , - 1 , $conf -> currency );
2014-03-19 23:49:07 +01:00
if ( $soc -> outstanding_limit != '' )
{
2015-04-18 19:08:01 +02:00
if ( $outstandingBills > $soc -> outstanding_limit ) print img_warning ( $langs -> trans ( " OutstandingBillReached " ));
2015-03-06 20:59:18 +01:00
print ' / ' . price ( $soc -> outstanding_limit , '' , $langs , 0 , 0 , - 1 , $conf -> currency );
2013-11-16 14:26:42 +01:00
}
print ')' ;
2013-08-06 23:50:12 +02:00
print '</td>' ;
2014-03-19 23:49:07 +01:00
}
else
{
2013-08-06 23:50:12 +02:00
print '<td colspan="2">' ;
2017-04-28 13:37:36 +02:00
print $form -> select_company ( $soc -> id , 'socid' , '(s.client = 1 OR s.client = 3) AND status=1' , 'SelectThirdParty' , 0 , 0 , null , 0 , 'minwidth300' );
2015-11-13 12:35:10 +01:00
// Option to reload page to retrieve customer informations. Note, this clear other input
2015-11-11 15:32:42 +01:00
if ( ! empty ( $conf -> global -> RELOAD_PAGE_ON_CUSTOMER_CHANGE ))
{
print ' < script type = " text/javascript " >
$ ( document ) . ready ( function () {
$ ( " #socid " ) . change ( function () {
var socid = $ ( this ) . val ();
2016-04-27 11:35:11 +02:00
var fac_rec = $ ( \ ' #fac_rec\').val();
2015-11-11 15:32:42 +01:00
// reload page
2016-04-27 11:35:11 +02:00
window . location . href = " '. $_SERVER["PHP_SELF"] .'?action=create&socid= " + socid + " &fac_rec= " + fac_rec ;
2015-11-11 15:32:42 +01:00
});
2015-11-06 16:14:00 +01:00
});
2015-11-11 15:32:42 +01:00
</ script > ' ;
}
2017-10-16 08:47:05 +02:00
print ' <a href="' . DOL_URL_ROOT . '/societe/card.php?action=create&client=3&fournisseur=0&backtopage=' . urlencode ( $_SERVER [ " PHP_SELF " ] . '?action=create' ) . '">' . $langs -> trans ( " AddThirdParty " ) . '</a>' ;
2013-08-06 23:50:12 +02:00
print '</td>' ;
}
2014-02-23 20:10:05 +01:00
print '</tr>' . " \n " ;
2014-03-01 19:45:13 +01:00
2016-12-04 21:27:08 +01:00
$exampletemplateinvoice = new FactureRec ( $db );
2016-12-24 21:39:40 +01:00
2016-09-19 16:27:01 +02:00
// Overwrite value if creation of invoice is from a predefined invoice
2016-01-08 16:30:43 +01:00
if ( empty ( $origin ) && empty ( $originid ) && GETPOST ( 'fac_rec' , 'int' ) > 0 )
2014-03-01 19:45:13 +01:00
{
2017-10-16 08:47:05 +02:00
$invoice_predefined = new FactureRec ( $db );
$invoice_predefined -> fetch ( GETPOST ( 'fac_rec' , 'int' ));
2016-08-10 09:47:25 +02:00
2017-10-16 08:47:05 +02:00
$dateinvoice = $invoice_predefined -> date_when ; // To use next gen date by default later
if ( empty ( $projectid )) $projectid = $invoice_predefined -> fk_project ;
$cond_reglement_id = $invoice_predefined -> cond_reglement_id ;
$mode_reglement_id = $invoice_predefined -> mode_reglement_id ;
$fk_account = $invoice_predefined -> fk_account ;
$note_public = $invoice_predefined -> note_public ;
$note_private = $invoice_predefined -> note_private ;
2016-07-19 07:46:27 +02:00
2013-04-20 17:10:03 +02:00
$sql = 'SELECT r.rowid, r.titre, r.total_ttc' ;
2014-02-23 20:10:05 +01:00
$sql .= ' FROM ' . MAIN_DB_PREFIX . 'facture_rec as r' ;
2016-01-08 16:30:43 +01:00
$sql .= ' WHERE r.fk_soc = ' . $invoice_predefined -> socid ;
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$resql = $db -> query ( $sql );
2014-03-01 19:45:13 +01:00
if ( $resql )
{
2013-04-20 17:10:03 +02:00
$num = $db -> num_rows ( $resql );
$i = 0 ;
2014-03-01 19:45:13 +01:00
if ( $num > 0 )
{
2014-02-23 20:10:05 +01:00
print '<tr><td>' . $langs -> trans ( 'CreateFromRepeatableInvoice' ) . '</td><td>' ;
2016-04-27 11:35:11 +02:00
print '<select class="flat" id="fac_rec" name="fac_rec">' ;
2015-05-07 12:20:20 +02:00
print '<option value="0" selected></option>' ;
2014-03-01 19:45:13 +01:00
while ( $i < $num )
{
2013-04-20 17:10:03 +02:00
$objp = $db -> fetch_object ( $resql );
2014-02-23 20:10:05 +01:00
print '<option value="' . $objp -> rowid . '"' ;
if ( GETPOST ( 'fac_rec' ) == $objp -> rowid )
2016-12-04 21:27:08 +01:00
{
2017-10-16 08:47:05 +02:00
print ' selected' ;
$exampletemplateinvoice -> fetch ( GETPOST ( 'fac_rec' ));
2016-12-04 21:27:08 +01:00
}
2014-02-23 20:10:05 +01:00
print '>' . $objp -> titre . ' (' . price ( $objp -> total_ttc ) . ' ' . $langs -> trans ( " TTC " ) . ')</option>' ;
$i ++ ;
2013-04-20 00:10:20 +02:00
}
2016-04-27 11:35:11 +02:00
print '</select>' ;
// Option to reload page to retrieve customer informations. Note, this clear other input
2017-10-16 08:47:05 +02:00
if ( ! empty ( $conf -> global -> RELOAD_PAGE_ON_TEMPLATE_CHANGE ))
{
print ' < script type = " text/javascript " >
2016-04-27 11:35:11 +02:00
$ ( document ) . ready ( function () {
$ ( " #fac_rec " ) . change ( function () {
var fac_rec = $ ( this ) . val ();
var socid = $ ( \ ' #socid\').val();
// reload page
window . location . href = " '. $_SERVER["PHP_SELF"] .'?action=create&socid= " + socid + " &fac_rec= " + fac_rec ;
});
});
</ script > ' ;
2017-10-16 08:47:05 +02:00
}
2016-04-27 11:35:11 +02:00
print '</td></tr>' ;
2013-04-20 00:10:20 +02:00
}
2014-02-23 20:10:05 +01:00
$db -> free ( $resql );
} else {
dol_print_error ( $db );
}
2013-04-20 17:10:03 +02:00
}
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
// Type de facture
$facids = $facturestatic -> list_replacable_invoices ( $soc -> id );
if ( $facids < 0 ) {
dol_print_error ( $db , $facturestatic );
exit ();
}
$options = " " ;
2014-03-01 19:45:13 +01:00
foreach ( $facids as $facparam )
{
2014-02-23 20:10:05 +01:00
$options .= '<option value="' . $facparam [ 'id' ] . '"' ;
2014-03-20 00:05:20 +01:00
if ( $facparam [ 'id' ] == $_POST [ 'fac_replacement' ])
2015-05-07 12:20:20 +02:00
$options .= ' selected' ;
2014-02-23 20:10:05 +01:00
$options .= '>' . $facparam [ 'ref' ];
$options .= ' (' . $facturestatic -> LibStatut ( 0 , $facparam [ 'status' ]) . ')' ;
$options .= '</option>' ;
}
2014-03-01 19:45:13 +01:00
2014-03-19 22:30:25 +01:00
// Show link for credit note
2013-04-20 17:10:03 +02:00
$facids = $facturestatic -> list_qualified_avoir_invoices ( $soc -> id );
if ( $facids < 0 )
{
dol_print_error ( $db , $facturestatic );
exit ;
2014-02-23 20:10:05 +01:00
}
$optionsav = " " ;
$newinvoice_static = new Facture ( $db );
2014-03-01 19:45:13 +01:00
foreach ( $facids as $key => $valarray )
{
2014-02-23 20:10:05 +01:00
$newinvoice_static -> id = $key ;
$newinvoice_static -> ref = $valarray [ 'ref' ];
$newinvoice_static -> statut = $valarray [ 'status' ];
$newinvoice_static -> type = $valarray [ 'type' ];
$newinvoice_static -> paye = $valarray [ 'paye' ];
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$optionsav .= '<option value="' . $key . '"' ;
2015-07-08 14:01:30 +02:00
if ( $key == GETPOST ( 'fac_avoir' ))
2015-05-07 12:20:20 +02:00
$optionsav .= ' selected' ;
2014-02-23 20:10:05 +01:00
$optionsav .= '>' ;
$optionsav .= $newinvoice_static -> ref ;
$optionsav .= ' (' . $newinvoice_static -> getLibStatut ( 1 , $valarray [ 'paymentornot' ]) . ')' ;
$optionsav .= '</option>' ;
}
2014-03-01 19:45:13 +01:00
2017-01-22 12:13:32 +01:00
print '<tr><td class="tdtop fieldrequired">' . $langs -> trans ( 'Type' ) . '</td><td colspan="2">' ;
2015-06-03 11:55:39 +02:00
print '<div class="tagtable">' . " \n " ;
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
// Standard invoice
2015-06-03 11:55:39 +02:00
print '<div class="tagtr listofinvoicetype"><div class="tagtd listofinvoicetype">' ;
$tmp = '<input type="radio" id="radio_standard" name="type" value="0"' . ( GETPOST ( 'type' ) == 0 ? ' checked' : '' ) . '> ' ;
2018-02-20 15:08:57 +01:00
$tmp = $tmp . '<label for="radio_standard" >' . $langs -> trans ( " InvoiceStandardAsk " ) . '</label>' ;
$desc = $form -> textwithpicto ( $tmp , $langs -> transnoentities ( " InvoiceStandardDesc " ), 1 , 'help' , '' , 0 , 3 );
2013-04-20 17:10:03 +02:00
print $desc ;
2015-06-03 11:55:39 +02:00
print '</div></div>' ;
2014-03-01 19:45:13 +01:00
if (( empty ( $origin )) || ((( $origin == 'propal' ) || ( $origin == 'commande' )) && ( ! empty ( $originid ))))
{
2013-04-20 17:10:03 +02:00
// Deposit
2017-06-07 16:44:04 +02:00
if ( empty ( $conf -> global -> INVOICE_DISABLE_DEPOSIT ))
2016-08-31 18:35:15 +02:00
{
2017-10-16 08:47:05 +02:00
print '<div class="tagtr listofinvoicetype"><div class="tagtd listofinvoicetype">' ;
$tmp = '<input type="radio" id="radio_deposit" name="type" value="3"' . ( GETPOST ( 'type' ) == 3 ? ' checked' : '' ) . '> ' ;
print ' < script type = " text/javascript " language = " javascript " >
2016-08-31 18:35:15 +02:00
jQuery ( document ) . ready ( function () {
jQuery ( " #typedeposit, #valuedeposit " ) . click ( function () {
jQuery ( " #radio_deposit " ) . prop ( " checked " , true );
});
});
</ script > ' ;
2017-06-07 16:44:04 +02:00
2018-02-20 15:08:57 +01:00
$tmp = $tmp . '<label for="radio_deposit" >' . $langs -> trans ( " InvoiceDeposit " ) . '</label>' ;
$desc = $form -> textwithpicto ( $tmp , $langs -> transnoentities ( " InvoiceDepositDesc " ), 1 , 'help' , '' , 0 , 3 );
2017-10-16 08:47:05 +02:00
print '<table class="nobordernopadding"><tr><td>' ;
print $desc ;
print '</td>' ;
if (( $origin == 'propal' ) || ( $origin == 'commande' ))
{
print '<td class="nowrap" style="padding-left: 5px">' ;
2018-07-06 12:45:20 +02:00
$arraylist = array ( 'amount' => $langs -> transnoentitiesnoconv ( 'FixAmount' ), 'variable' => $langs -> transnoentitiesnoconv ( 'VarAmountOneLine' , $langs -> transnoentitiesnoconv ( 'Deposit' )));
2017-10-16 08:47:05 +02:00
print $form -> selectarray ( 'typedeposit' , $arraylist , GETPOST ( 'typedeposit' ), 0 , 0 , 0 , '' , 1 );
print '</td>' ;
print '<td class="nowrap" style="padding-left: 5px">' . $langs -> trans ( 'Value' ) . ':<input type="text" id="valuedeposit" name="valuedeposit" size="3" value="' . GETPOST ( 'valuedeposit' , 'int' ) . '"/>' ;
}
print '</td></tr></table>' ;
print '</div></div>' ;
2016-08-31 18:35:15 +02:00
}
2013-04-20 17:10:03 +02:00
}
2014-03-01 19:45:13 +01:00
if ( $socid > 0 )
{
2015-01-18 18:44:22 +01:00
if ( ! empty ( $conf -> global -> INVOICE_USE_SITUATION ))
{
2015-06-03 11:55:39 +02:00
// First situation invoice
print '<div class="tagtr listofinvoicetype"><div class="tagtd listofinvoicetype">' ;
2018-02-20 15:08:57 +01:00
$tmp = '<input id="radio_situation invoice" type="radio" name="type" value="5"' . ( GETPOST ( 'type' ) == 5 ? ' checked' : '' ) . '> ' ;
$tmp = $tmp . '<label for="radio_situation invoice" >' . $langs -> trans ( " InvoiceFirstSituationAsk " ) . '</label>' ;
$desc = $form -> textwithpicto ( $tmp , $langs -> transnoentities ( " InvoiceFirstSituationDesc " ), 1 , 'help' , '' , 0 , 3 );
2015-06-03 11:55:39 +02:00
print $desc ;
print '</div></div>' ;
// Next situation invoice
2015-06-06 14:21:18 +02:00
$opt = $form -> selectSituationInvoices ( GETPOST ( 'originid' ), $socid );
2015-06-03 11:55:39 +02:00
print '<div class="tagtr listofinvoicetype"><div class="tagtd listofinvoicetype">' ;
$tmp = '<input type="radio" name="type" value="5"' . ( GETPOST ( 'type' ) == 5 && GETPOST ( 'originid' ) ? ' checked' : '' );
2016-01-13 13:42:58 +01:00
if ( $opt == ( '<option value ="0" selected>' . $langs -> trans ( 'NoSituations' ) . '</option>' ) || ( GETPOST ( 'origin' ) && GETPOST ( 'origin' ) != 'facture' && GETPOST ( 'origin' ) != 'commande' )) $tmp .= ' disabled' ;
2015-06-03 11:55:39 +02:00
$tmp .= '> ' ;
2018-02-20 15:08:57 +01:00
$text = '<label>' . $tmp . $langs -> trans ( " InvoiceSituationAsk " ) . '</label> ' ;
2015-06-03 11:55:39 +02:00
$text .= '<select class="flat" id="situations" name="situations">' ;
$text .= $opt ;
$text .= '</select>' ;
2016-03-25 15:24:57 +01:00
$desc = $form -> textwithpicto ( $text , $langs -> transnoentities ( " InvoiceSituationDesc " ), 1 , 'help' , '' , 0 , 3 );
2015-06-03 11:55:39 +02:00
print $desc ;
print '</div></div>' ;
2015-01-18 18:44:22 +01:00
}
2015-01-25 21:32:40 +01:00
2013-04-20 17:10:03 +02:00
// Replacement
2017-06-07 16:44:04 +02:00
if ( empty ( $conf -> global -> INVOICE_DISABLE_REPLACEMENT ))
2016-08-31 18:35:15 +02:00
{
2017-10-16 08:47:05 +02:00
print '<!-- replacement line -->' ;
print '<div class="tagtr listofinvoicetype"><div class="tagtd listofinvoicetype">' ;
$tmp = '<input type="radio" name="type" id="radio_replacement" value="1"' . ( GETPOST ( 'type' ) == 1 ? ' checked' : '' );
if ( ! $options ) $tmp .= ' disabled' ;
$tmp .= '> ' ;
print ' < script type = " text/javascript " language = " javascript " >
2016-08-31 18:35:15 +02:00
jQuery ( document ) . ready ( function () {
jQuery ( " #fac_replacement " ) . change ( function () {
jQuery ( " #radio_replacement " ) . prop ( " checked " , true );
});
});
</ script > ' ;
2018-02-20 15:08:57 +01:00
$text = '<label>' . $tmp . $langs -> trans ( " InvoiceReplacementAsk " ) . '</label>' ;
2017-10-16 08:47:05 +02:00
$text .= '<select class="flat" name="fac_replacement" id="fac_replacement"' ;
if ( ! $options )
$text .= ' disabled' ;
$text .= '>' ;
if ( $options ) {
$text .= '<option value="-1"> </option>' ;
$text .= $options ;
} else {
$text .= '<option value="-1">' . $langs -> trans ( " NoReplacableInvoice " ) . '</option>' ;
}
$text .= '</select>' ;
$desc = $form -> textwithpicto ( $text , $langs -> transnoentities ( " InvoiceReplacementDesc " ), 1 , 'help' , '' , 0 , 3 );
print $desc ;
print '</div></div>' ;
2014-02-23 20:10:05 +01:00
}
2013-04-20 17:10:03 +02:00
}
2014-03-19 23:49:07 +01:00
else
{
2015-06-03 11:55:39 +02:00
print '<div class="tagtr listofinvoicetype"><div class="tagtd listofinvoicetype">' ;
$tmp = '<input type="radio" name="type" id="radio_replacement" value="0" disabled> ' ;
2018-02-20 15:08:57 +01:00
$text = '<label>' . $tmp . $langs -> trans ( " InvoiceReplacement " ) . '</label> ' ;
2014-03-19 23:49:07 +01:00
$text .= '(' . $langs -> trans ( " YouMustCreateInvoiceFromThird " ) . ') ' ;
2016-03-25 15:24:57 +01:00
$desc = $form -> textwithpicto ( $text , $langs -> transnoentities ( " InvoiceReplacementDesc " ), 1 , 'help' , '' , 0 , 3 );
2014-03-19 23:49:07 +01:00
print $desc ;
2015-06-03 11:55:39 +02:00
print '</div></div>' ;
2014-03-19 23:49:07 +01:00
}
2014-03-01 19:45:13 +01:00
2018-10-30 14:47:39 +01:00
2014-03-19 23:49:07 +01:00
if ( empty ( $origin ))
2014-03-01 19:45:13 +01:00
{
2014-03-19 23:49:07 +01:00
if ( $socid > 0 )
{
2017-10-16 08:47:05 +02:00
// Credit note
if ( empty ( $conf -> global -> INVOICE_DISABLE_CREDIT_NOTE ))
{
print '<div class="tagtr listofinvoicetype"><div class="tagtd listofinvoicetype">' ;
$tmp = '<input type="radio" id="radio_creditnote" name="type" value="2"' . ( GETPOST ( 'type' ) == 2 ? ' checked' : '' );
if ( ! $optionsav ) $tmp .= ' disabled' ;
$tmp .= '> ' ;
// Show credit note options only if we checked credit note
print ' < script type = " text/javascript " language = " javascript " >
2016-08-31 18:35:15 +02:00
jQuery ( document ) . ready ( function () {
if ( ! jQuery ( " #radio_creditnote " ) . is ( " :checked " ))
{
jQuery ( " #credit_note_options " ) . hide ();
}
jQuery ( " #radio_creditnote " ) . click ( function () {
jQuery ( " #credit_note_options " ) . show ();
});
jQuery ( " #radio_standard, #radio_replacement, #radio_deposit " ) . click ( function () {
jQuery ( " #credit_note_options " ) . hide ();
});
});
</ script > ' ;
2018-02-20 15:08:57 +01:00
$text = '<label>' . $tmp . $langs -> transnoentities ( " InvoiceAvoirAsk " ) . '</label> ' ;
2017-10-16 08:47:05 +02:00
// $text.='<input type="text" value="">';
$text .= '<select class="flat valignmiddle" name="fac_avoir" id="fac_avoir"' ;
if ( ! $optionsav )
$text .= ' disabled' ;
$text .= '>' ;
if ( $optionsav ) {
$text .= '<option value="-1"></option>' ;
$text .= $optionsav ;
} else {
$text .= '<option value="-1">' . $langs -> trans ( " NoInvoiceToCorrect " ) . '</option>' ;
}
$text .= '</select>' ;
$desc = $form -> textwithpicto ( $text , $langs -> transnoentities ( " InvoiceAvoirDesc " ), 1 , 'help' , '' , 0 , 3 );
print $desc ;
print '<div id="credit_note_options" class="clearboth">' ;
2017-12-20 13:28:41 +01:00
print ' <input type="checkbox" name="invoiceAvoirWithLines" id="invoiceAvoirWithLines" value="1" onclick="$(\'#credit_note_options input[type=checkbox]\').not(this).prop(\'checked\', false);" ' . ( GETPOST ( 'invoiceAvoirWithLines' , 'int' ) > 0 ? 'checked' : '' ) . ' /> <label for="invoiceAvoirWithLines">' . $langs -> trans ( 'invoiceAvoirWithLines' ) . " </label> " ;
print '<br> <input type="checkbox" name="invoiceAvoirWithPaymentRestAmount" id="invoiceAvoirWithPaymentRestAmount" value="1" onclick="$(\'#credit_note_options input[type=checkbox]\').not(this).prop(\'checked\', false);" ' . ( GETPOST ( 'invoiceAvoirWithPaymentRestAmount' , 'int' ) > 0 ? 'checked' : '' ) . ' /> <label for="invoiceAvoirWithPaymentRestAmount">' . $langs -> trans ( 'invoiceAvoirWithPaymentRestAmount' ) . " </label> " ;
2017-10-16 08:47:05 +02:00
print '</div>' ;
2016-08-31 18:35:15 +02:00
print '</div></div>' ;
}
2014-03-19 23:49:07 +01:00
}
else
{
2015-06-03 11:55:39 +02:00
print '<div class="tagtr listofinvoicetype"><div class="tagtd listofinvoicetype">' ;
2017-05-11 12:48:47 +02:00
if ( empty ( $conf -> global -> INVOICE_CREDIT_NOTE_STANDALONE )) $tmp = '<input type="radio" name="type" id="radio_creditnote" value="0" disabled> ' ;
else $tmp = '<input type="radio" name="type" id="radio_creditnote" value="2" > ' ;
2018-02-20 15:08:57 +01:00
$text = '<label>' . $tmp . $langs -> trans ( " InvoiceAvoir " ) . '</label> ' ;
2014-03-19 23:49:07 +01:00
$text .= '(' . $langs -> trans ( " YouMustCreateInvoiceFromThird " ) . ') ' ;
2016-03-25 15:24:57 +01:00
$desc = $form -> textwithpicto ( $text , $langs -> transnoentities ( " InvoiceAvoirDesc " ), 1 , 'help' , '' , 0 , 3 );
2014-03-19 23:49:07 +01:00
print $desc ;
2015-06-03 11:55:39 +02:00
print '</div></div>' . " \n " ;
2014-02-23 20:10:05 +01:00
}
2013-04-20 17:10:03 +02:00
}
2017-06-07 16:44:04 +02:00
2016-04-24 18:11:19 +02:00
// Template invoice
print '<div class="tagtr listofinvoicetype"><div class="tagtd listofinvoicetype">' ;
$tmp = '<input type="radio" name="type" id="radio_template" value="0" disabled> ' ;
2018-02-20 15:08:57 +01:00
$text = '<label>' . $tmp . $langs -> trans ( " RepeatableInvoice " ) . '</label> ' ;
2016-04-24 18:11:19 +02:00
//$text.= '('.$langs->trans("YouMustCreateStandardInvoiceFirst").') ';
$desc = $form -> textwithpicto ( $text , $langs -> transnoentities ( " YouMustCreateStandardInvoiceFirstDesc " ), 1 , 'help' , '' , 0 , 3 );
print $desc ;
print '</div></div>' ;
2016-08-10 09:47:25 +02:00
2015-06-03 11:55:39 +02:00
print '</div>' ;
2018-10-30 14:47:39 +01:00
2018-10-02 15:51:17 +02:00
if ( ! empty ( $conf -> global -> INVOICE_USE_DEFAULT_DOCUMENT )) // Hidden conf
2018-02-20 15:08:57 +01:00
{
2018-10-02 15:51:17 +02:00
// Add auto select default document model
$listtType = array ( Facture :: TYPE_STANDARD , Facture :: TYPE_REPLACEMENT , Facture :: TYPE_CREDIT_NOTE , Facture :: TYPE_DEPOSIT , Facture :: TYPE_SITUATION );
$jsListType = '' ;
foreach ( $listtType as $type )
{
$thisTypeConfName = 'FACTURE_ADDON_PDF_' . $type ;
$curent = ! empty ( $conf -> global -> { $thisTypeConfName }) ? $conf -> global -> { $thisTypeConfName } : $conf -> global -> FACTURE_ADDON_PDF ;
$jsListType .= ( ! empty ( $jsListType ) ? ',' : '' ) . '"' . $type . '":"' . $curent . '"' ;
}
2018-10-30 14:47:39 +01:00
2018-10-02 15:51:17 +02:00
print ' < script type = " text/javascript " language = " javascript " >
$ ( document ) . ready ( function () {
var listType = { '.$jsListType.' };
$ ( " [name= \ 'type \ ' " ) . change ( function () {
if ( $ ( this ) . prop ( " checked " ))
2018-02-20 15:08:57 +01:00
{
2018-10-02 15:51:17 +02:00
if (( $ ( this ) . val () in listType ))
{
$ ( " #model " ) . val ( listType [ $ ( this ) . val ()]);
}
else
{
$ ( " #model " ) . val ( " '. $conf->global ->FACTURE_ADDON_PDF.' " );
}
2018-02-20 15:08:57 +01:00
}
2018-10-02 15:51:17 +02:00
});
});
</ script > ' ;
}
2018-10-30 14:47:39 +01:00
2013-04-20 17:10:03 +02:00
print '</td></tr>' ;
2014-03-01 19:45:13 +01:00
2014-03-20 00:05:20 +01:00
if ( $socid > 0 )
{
2013-04-20 17:10:03 +02:00
// Discounts for third party
2014-02-23 20:10:05 +01:00
print '<tr><td>' . $langs -> trans ( 'Discounts' ) . '</td><td colspan="2">' ;
2018-03-02 16:48:25 +01:00
$thirdparty = $soc ;
$discount_type = 0 ;
$backtopage = urlencode ( $_SERVER [ " PHP_SELF " ] . '?socid=' . $thirdparty -> id . '&action=' . $action . '&origin=' . GETPOST ( 'origin' ) . '&originid=' . GETPOST ( 'originid' ));
include DOL_DOCUMENT_ROOT . '/core/tpl/object_discounts.tpl.php' ;
2012-06-09 19:16:31 +02:00
print '</td></tr>' ;
2013-04-20 17:10:03 +02:00
}
2014-03-01 19:45:13 +01:00
2016-12-04 21:27:08 +01:00
$datefacture = dol_mktime ( 12 , 0 , 0 , $_POST [ 'remonth' ], $_POST [ 'reday' ], $_POST [ 'reyear' ]);
2016-12-24 21:39:40 +01:00
2013-04-20 17:10:03 +02:00
// Date invoice
2016-08-31 06:27:35 +02:00
print '<tr><td class="fieldrequired">' . $langs -> trans ( 'DateInvoice' ) . '</td><td colspan="2">' ;
2018-09-09 09:36:12 +02:00
print $form -> selectDate ( $datefacture ? $datefacture : $dateinvoice , '' , '' , '' , '' , " add " , 1 , 1 );
2013-04-20 17:10:03 +02:00
print '</td></tr>' ;
2014-03-01 19:45:13 +01:00
2016-05-29 23:56:58 +02:00
// Date point of tax
if ( ! empty ( $conf -> global -> INVOICE_POINTOFTAX_DATE ))
{
print '<tr><td class="fieldrequired">' . $langs -> trans ( 'DatePointOfTax' ) . '</td><td colspan="2">' ;
$date_pointoftax = dol_mktime ( 12 , 0 , 0 , $_POST [ 'date_pointoftaxmonth' ], $_POST [ 'date_pointoftaxday' ], $_POST [ 'date_pointoftaxyear' ]);
2018-09-09 09:36:12 +02:00
print $form -> selectDate ( $date_pointoftax ? $date_pointoftax :- 1 , 'date_pointoftax' , '' , '' , '' , " add " , 1 , 1 );
2016-05-29 23:56:58 +02:00
print '</td></tr>' ;
}
2016-08-10 09:47:25 +02:00
2013-04-20 17:10:03 +02:00
// Payment term
2016-09-08 18:13:23 +02:00
print '<tr><td class="nowrap fieldrequired">' . $langs -> trans ( 'PaymentConditionsShort' ) . '</td><td colspan="2">' ;
2014-03-20 00:05:20 +01:00
$form -> select_conditions_paiements ( isset ( $_POST [ 'cond_reglement_id' ]) ? $_POST [ 'cond_reglement_id' ] : $cond_reglement_id , 'cond_reglement_id' );
2013-04-20 17:10:03 +02:00
print '</td></tr>' ;
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
// Payment mode
2014-02-23 20:10:05 +01:00
print '<tr><td>' . $langs -> trans ( 'PaymentMode' ) . '</td><td colspan="2">' ;
2014-09-07 12:22:04 +02:00
$form -> select_types_paiements ( isset ( $_POST [ 'mode_reglement_id' ]) ? $_POST [ 'mode_reglement_id' ] : $mode_reglement_id , 'mode_reglement_id' , 'CRDT' );
2013-04-20 17:10:03 +02:00
print '</td></tr>' ;
2014-03-01 19:45:13 +01:00
2017-10-16 08:47:05 +02:00
// Bank Account
2015-09-01 16:25:34 +02:00
if ( isset ( $_POST [ 'fk_account' ])) {
$fk_account = $_POST [ 'fk_account' ];
}
2017-10-16 08:47:05 +02:00
print '<tr><td>' . $langs -> trans ( 'BankAccount' ) . '</td><td colspan="2">' ;
$form -> select_comptes ( $fk_account , 'fk_account' , 0 , '' , 1 );
print '</td></tr>' ;
2014-07-07 17:59:04 +02:00
2013-04-20 17:10:03 +02:00
// Project
2017-12-12 10:13:48 +01:00
if ( ! empty ( $conf -> projet -> enabled ))
2015-06-03 11:55:39 +02:00
{
2013-04-20 17:10:03 +02:00
$langs -> load ( 'projects' );
2014-02-23 20:10:05 +01:00
print '<tr><td>' . $langs -> trans ( 'Project' ) . '</td><td colspan="2">' ;
2017-12-12 10:13:48 +01:00
$numprojet = $formproject -> select_projects (( $socid > 0 ? $socid : - 1 ), $projectid , 'projectid' , 0 , 0 , 1 , 1 );
2016-04-27 10:56:40 +02:00
print ' <a href="' . DOL_URL_ROOT . '/projet/card.php?socid=' . $soc -> id . '&action=create&status=1&backtopage=' . urlencode ( $_SERVER [ " PHP_SELF " ] . '?action=create&socid=' . $soc -> id . ( $fac_rec ? '&fac_rec=' . $fac_rec : '' )) . '">' . $langs -> trans ( " AddProject " ) . '</a>' ;
2013-04-20 00:10:20 +02:00
print '</td></tr>' ;
2013-04-20 17:10:03 +02:00
}
2014-03-01 19:45:13 +01:00
2015-02-23 09:16:14 +01:00
// Incoterms
if ( ! empty ( $conf -> incoterm -> enabled ))
{
print '<tr>' ;
2016-03-25 15:24:57 +01:00
print '<td><label for="incoterm_id">' . $form -> textwithpicto ( $langs -> trans ( " IncotermLabel " ), $objectsrc -> libelle_incoterms , 1 ) . '</label></td>' ;
2017-10-16 08:47:05 +02:00
print '<td colspan="2" class="maxwidthonsmartphone">' ;
$incoterm_id = GETPOST ( 'incoterm_id' );
$incoterm_location = GETPOST ( 'location_incoterms' );
if ( empty ( $incoterm_id ))
{
$incoterm_id = ( ! empty ( $objectsrc -> fk_incoterms ) ? $objectsrc -> fk_incoterms : $soc -> fk_incoterms );
$incoterm_location = ( ! empty ( $objectsrc -> location_incoterms ) ? $objectsrc -> location_incoterms : $soc -> location_incoterms );
}
print $form -> select_incoterms ( $incoterm_id , $incoterm_location );
2015-02-23 09:16:14 +01:00
print '</td></tr>' ;
}
2015-03-18 14:31:37 +01:00
2013-04-20 17:10:03 +02:00
// Other attributes
2017-06-07 16:44:04 +02:00
$parameters = array ( 'objectsrc' => $objectsrc , 'colspan' => ' colspan="2"' , 'cols' => 2 );
$reshook = $hookmanager -> executeHooks ( 'formObjectOptions' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
2017-10-16 08:47:05 +02:00
print $hookmanager -> resPrint ;
2018-04-13 13:28:48 +02:00
if ( empty ( $reshook )) {
2014-02-23 20:10:05 +01:00
print $object -> showOptionals ( $extrafields , 'edit' );
2013-04-20 17:10:03 +02:00
}
2014-03-01 19:45:13 +01:00
2015-06-03 11:55:39 +02:00
// Template to use by default
2014-02-23 20:10:05 +01:00
print '<tr><td>' . $langs -> trans ( 'Model' ) . '</td>' ;
2016-02-15 00:58:51 +01:00
print '<td colspan="2">' ;
2014-02-23 20:10:05 +01:00
include_once DOL_DOCUMENT_ROOT . '/core/modules/facture/modules_facture.php' ;
$liste = ModelePDFFactures :: liste_modeles ( $db );
2018-10-02 15:51:17 +02:00
if ( ! empty ( $conf -> global -> INVOICE_USE_DEFAULT_DOCUMENT )){ // Hidden conf
$paramkey = 'FACTURE_ADDON_PDF_' . $object -> type ;
$curent = ! empty ( $conf -> global -> $paramkey ) ? $conf -> global -> $paramkey : $conf -> global -> FACTURE_ADDON_PDF ;
}
else {
$curent = $conf -> global -> FACTURE_ADDON_PDF ;
}
2018-02-20 15:08:57 +01:00
print $form -> selectarray ( 'model' , $liste , $curent );
2013-04-20 17:10:03 +02:00
print " </td></tr> " ;
2014-03-01 19:45:13 +01:00
2016-01-23 16:01:55 +01:00
// Multicurrency
if ( ! empty ( $conf -> multicurrency -> enabled ))
{
print '<tr>' ;
2018-10-27 17:45:29 +02:00
print '<td>' . $form -> editfieldkey ( 'Currency' , 'multicurrency_code' , '' , $object , 0 ) . '</td>' ;
2017-10-16 08:47:05 +02:00
print '<td colspan="2" class="maxwidthonsmartphone">' ;
print $form -> selectMultiCurrency ( $currency_code , 'multicurrency_code' );
2016-01-23 16:01:55 +01:00
print '</td></tr>' ;
}
2016-08-10 09:47:25 +02:00
2016-12-04 21:27:08 +01:00
// Help of substitution key
$htmltext = '' ;
if ( GETPOST ( 'fac_rec' , 'int' ) > 0 )
{
2017-10-16 08:47:05 +02:00
$dateexample = ( $datefacture ? $datefacture : $dateinvoice );
if ( empty ( $dateexample )) $dateexample = dol_now ();
$substitutionarray = array (
'__TOTAL_HT__' => $langs -> trans ( " AmountHT " ) . ' (' . $langs -> trans ( " Example " ) . ': ' . price ( $exampletemplateinvoice -> total_ht ) . ')' ,
'__TOTAL_TTC__' => $langs -> trans ( " AmountTTC " ) . ' (' . $langs -> trans ( " Example " ) . ': ' . price ( $exampletemplateinvoice -> total_ttc ) . ')' ,
'__INVOICE_PREVIOUS_MONTH__' => $langs -> trans ( " PreviousMonthOfInvoice " ) . ' (' . $langs -> trans ( " Example " ) . ': ' . dol_print_date ( dol_time_plus_duree ( $dateexample , - 1 , 'm' ), '%m' ) . ')' ,
'__INVOICE_MONTH__' => $langs -> trans ( " MonthOfInvoice " ) . ' (' . $langs -> trans ( " Example " ) . ': ' . dol_print_date ( $dateexample , '%m' ) . ')' ,
'__INVOICE_NEXT_MONTH__' => $langs -> trans ( " NextMonthOfInvoice " ) . ' (' . $langs -> trans ( " Example " ) . ': ' . dol_print_date ( dol_time_plus_duree ( $dateexample , 1 , 'm' ), '%m' ) . ')' ,
'__INVOICE_PREVIOUS_MONTH_TEXT__' => $langs -> trans ( " TextPreviousMonthOfInvoice " ) . ' (' . $langs -> trans ( " Example " ) . ': ' . dol_print_date ( dol_time_plus_duree ( $dateexample , - 1 , 'm' ), '%B' ) . ')' ,
'__INVOICE_MONTH_TEXT__' => $langs -> trans ( " TextMonthOfInvoice " ) . ' (' . $langs -> trans ( " Example " ) . ': ' . dol_print_date ( $dateexample , '%B' ) . ')' ,
'__INVOICE_NEXT_MONTH_TEXT__' => $langs -> trans ( " TextNextMonthOfInvoice " ) . ' (' . $langs -> trans ( " Example " ) . ': ' . dol_print_date ( dol_time_plus_duree ( $dateexample , 1 , 'm' ), '%B' ) . ')' ,
'__INVOICE_PREVIOUS_YEAR__' => $langs -> trans ( " YearOfInvoice " ) . ' (' . $langs -> trans ( " Example " ) . ': ' . dol_print_date ( dol_time_plus_duree ( $dateexample , - 1 , 'y' ), '%Y' ) . ')' ,
'__INVOICE_YEAR__' => $langs -> trans ( " PreviousYearOfInvoice " ) . ' (' . $langs -> trans ( " Example " ) . ': ' . dol_print_date ( $dateexample , '%Y' ) . ')' ,
'__INVOICE_NEXT_YEAR__' => $langs -> trans ( " NextYearOfInvoice " ) . ' (' . $langs -> trans ( " Example " ) . ': ' . dol_print_date ( dol_time_plus_duree ( $dateexample , 1 , 'y' ), '%Y' ) . ')'
);
$htmltext = '<i>' . $langs -> trans ( " FollowingConstantsWillBeSubstituted " ) . ':<br>' ;
foreach ( $substitutionarray as $key => $val )
{
$htmltext .= $key . ' = ' . $langs -> trans ( $val ) . '<br>' ;
}
$htmltext .= '</i>' ;
2016-12-04 21:27:08 +01:00
}
2016-12-24 21:39:40 +01:00
2013-04-20 17:10:03 +02:00
// Public note
print '<tr>' ;
2017-04-11 20:07:35 +02:00
print '<td class="tdtop">' ;
2016-12-04 21:27:08 +01:00
print $form -> textwithpicto ( $langs -> trans ( 'NotePublic' ), $htmltext );
print '</td>' ;
2013-04-20 17:10:03 +02:00
print '<td valign="top" colspan="2">' ;
2015-06-03 11:55:39 +02:00
$doleditor = new DolEditor ( 'note_public' , $note_public , '' , 80 , 'dolibarr_notes' , 'In' , 0 , false , true , ROWS_3 , '90%' );
2013-04-20 17:10:03 +02:00
print $doleditor -> Create ( 1 );
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
// Private note
2014-06-28 19:47:51 +02:00
if ( empty ( $user -> societe_id ))
{
2013-04-20 00:10:20 +02:00
print '<tr>' ;
2017-04-11 20:07:35 +02:00
print '<td class="tdtop">' ;
2016-12-04 21:27:08 +01:00
print $form -> textwithpicto ( $langs -> trans ( 'NotePrivate' ), $htmltext );
print '</td>' ;
2013-04-20 00:10:20 +02:00
print '<td valign="top" colspan="2">' ;
2015-06-03 11:55:39 +02:00
$doleditor = new DolEditor ( 'note_private' , $note_private , '' , 80 , 'dolibarr_notes' , 'In' , 0 , false , true , ROWS_3 , '90%' );
2013-04-20 00:10:20 +02:00
print $doleditor -> Create ( 1 );
2014-06-28 19:47:51 +02:00
// print '<textarea name="note_private" wrap="soft" cols="70" rows="'.ROWS_3.'">'.$note_private.'.</textarea>
print '</td></tr>' ;
2013-04-20 17:10:03 +02:00
}
2014-03-01 19:45:13 +01:00
2014-06-28 19:47:51 +02:00
// Lines from source
if ( ! empty ( $origin ) && ! empty ( $originid ) && is_object ( $objectsrc ))
{
2013-04-20 17:10:03 +02:00
// TODO for compatibility
2014-02-23 20:10:05 +01:00
if ( $origin == 'contrat' ) {
2013-04-20 17:10:03 +02:00
// Calcul contrat->price (HT), contrat->total (TTC), contrat->tva
2014-02-23 20:10:05 +01:00
$objectsrc -> remise_absolue = $remise_absolue ;
$objectsrc -> remise_percent = $remise_percent ;
$objectsrc -> update_price ( 1 , - 1 , 1 );
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
print " \n <!-- " . $classname . " info --> " ;
2013-04-20 17:10:03 +02:00
print " \n " ;
2014-02-23 20:10:05 +01:00
print '<input type="hidden" name="amount" value="' . $objectsrc -> total_ht . '">' . " \n " ;
print '<input type="hidden" name="total" value="' . $objectsrc -> total_ttc . '">' . " \n " ;
print '<input type="hidden" name="tva" value="' . $objectsrc -> total_tva . '">' . " \n " ;
print '<input type="hidden" name="origin" value="' . $objectsrc -> element . '">' ;
print '<input type="hidden" name="originid" value="' . $objectsrc -> id . '">' ;
2014-03-01 19:45:13 +01:00
2018-07-02 16:22:40 +02:00
switch ( get_class ( $objectsrc )) {
2015-04-04 17:28:24 +02:00
case 'Propal' :
$newclassname = 'CommercialProposal' ;
break ;
case 'Commande' :
$newclassname = 'Order' ;
break ;
case 'Expedition' :
$newclassname = 'Sending' ;
break ;
case 'Contrat' :
$newclassname = 'Contract' ;
break ;
2015-04-12 12:03:59 +02:00
case 'Fichinter' :
$newclassname = 'Intervention' ;
break ;
2015-04-04 17:28:24 +02:00
default :
2018-07-02 16:46:30 +02:00
$newclassname = get_class ( $objectsrc );
2015-04-04 17:28:24 +02:00
}
2014-03-01 19:45:13 +01:00
2014-08-07 16:23:02 +02:00
print '<tr><td>' . $langs -> trans ( $newclassname ) . '</td><td colspan="2">' . $objectsrc -> getNomUrl ( 1 );
2015-10-20 02:34:53 +02:00
// We check if Origin document (id and type is known) has already at least one invoice attached to it
$objectsrc -> fetchObjectLinked ( $originid , $origin , '' , 'facture' );
2018-10-12 17:51:32 +02:00
if ( is_array ( $objectsrc -> linkedObjects [ 'facture' ]) && count ( $objectsrc -> linkedObjects [ 'facture' ]) >= 1 )
2014-08-07 16:23:02 +02:00
{
2017-10-16 08:47:05 +02:00
setEventMessages ( 'WarningBillExist' , null , 'warnings' );
echo ' (' . $langs -> trans ( 'LatestRelatedBill' ) . end ( $objectsrc -> linkedObjects [ 'facture' ]) -> getNomUrl ( 1 ) . ')' ;
2014-08-07 16:23:02 +02:00
}
echo '</td></tr>' ;
2014-02-23 20:10:05 +01:00
print '<tr><td>' . $langs -> trans ( 'TotalHT' ) . '</td><td colspan="2">' . price ( $objectsrc -> total_ht ) . '</td></tr>' ;
print '<tr><td>' . $langs -> trans ( 'TotalVAT' ) . '</td><td colspan="2">' . price ( $objectsrc -> total_tva ) . " </td></tr> " ;
2014-07-04 16:48:42 +02:00
if ( $mysoc -> localtax1_assuj == " 1 " || $objectsrc -> total_localtax1 != 0 ) // Localtax1
2014-02-23 20:10:05 +01:00
{
print '<tr><td>' . $langs -> transcountry ( " AmountLT1 " , $mysoc -> country_code ) . '</td><td colspan="2">' . price ( $objectsrc -> total_localtax1 ) . " </td></tr> " ;
}
2014-03-01 19:45:13 +01:00
2014-07-04 16:48:42 +02:00
if ( $mysoc -> localtax2_assuj == " 1 " || $objectsrc -> total_localtax2 != 0 ) // Localtax2
2014-02-23 20:10:05 +01:00
{
print '<tr><td>' . $langs -> transcountry ( " AmountLT2 " , $mysoc -> country_code ) . '</td><td colspan="2">' . price ( $objectsrc -> total_localtax2 ) . " </td></tr> " ;
}
print '<tr><td>' . $langs -> trans ( 'TotalTTC' ) . '</td><td colspan="2">' . price ( $objectsrc -> total_ttc ) . " </td></tr> " ;
2016-08-10 09:47:25 +02:00
2016-01-23 16:01:55 +01:00
if ( ! empty ( $conf -> multicurrency -> enabled ))
{
2017-06-23 11:09:29 +02:00
print '<tr><td>' . $langs -> trans ( 'MulticurrencyAmountHT' ) . '</td><td colspan="2">' . price ( $objectsrc -> multicurrency_total_ht ) . '</td></tr>' ;
print '<tr><td>' . $langs -> trans ( 'MulticurrencyAmountVAT' ) . '</td><td colspan="2">' . price ( $objectsrc -> multicurrency_total_tva ) . " </td></tr> " ;
print '<tr><td>' . $langs -> trans ( 'MulticurrencyAmountTTC' ) . '</td><td colspan="2">' . price ( $objectsrc -> multicurrency_total_ttc ) . " </td></tr> " ;
2016-01-23 16:01:55 +01:00
}
2015-06-03 11:55:39 +02:00
}
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
print " </table> \n " ;
2014-03-01 19:45:13 +01:00
2015-05-13 17:53:25 +02:00
dol_fiche_end ();
2015-05-19 00:01:30 +02:00
2013-04-20 17:10:03 +02:00
// Button "Create Draft"
2015-05-13 17:53:25 +02:00
print '<div class="center">' ;
2014-06-28 19:47:51 +02:00
print '<input type="submit" class="button" name="bouton" value="' . $langs -> trans ( 'CreateDraft' ) . '">' ;
2015-05-28 05:25:29 +02:00
print ' ' ;
2014-11-25 20:13:43 +01:00
print '<input type="button" class="button" value="' . $langs -> trans ( " Cancel " ) . '" onClick="javascript:history.go(-1)">' ;
print '</div>' ;
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
print " </form> \n " ;
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
// Show origin lines
2014-02-23 20:10:05 +01:00
if ( ! empty ( $origin ) && ! empty ( $originid ) && is_object ( $objectsrc )) {
2013-04-20 17:10:03 +02:00
print '<br>' ;
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$title = $langs -> trans ( 'ProductsAndServices' );
2015-09-24 18:27:13 +02:00
print load_fiche_titre ( $title );
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
print '<table class="noborder" width="100%">' ;
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
$objectsrc -> printOriginLinesList ();
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
print '</table>' ;
2013-04-20 00:10:20 +02:00
}
2014-03-01 19:45:13 +01:00
2013-09-21 10:53:46 +02:00
print '<br>' ;
2015-07-04 03:28:52 +02:00
}
else if ( $id > 0 || ! empty ( $ref ))
2015-06-23 23:33:25 +02:00
{
2013-04-20 17:10:03 +02:00
/*
* Show object in view mode
2013-11-17 23:25:25 +01:00
*/
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$result = $object -> fetch ( $id , $ref );
if ( $result <= 0 ) {
dol_print_error ( $db , $object -> error );
exit ();
}
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
// fetch optionals attributes and labels
2014-02-23 20:10:05 +01:00
$extralabels = $extrafields -> fetch_name_optionals_label ( $object -> table_element );
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
if ( $user -> societe_id > 0 && $user -> societe_id != $object -> socid )
accessforbidden ( '' , 0 );
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$result = $object -> fetch_thirdparty ();
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
$soc = new Societe ( $db );
2015-06-23 23:33:25 +02:00
$result = $soc -> fetch ( $object -> socid );
if ( $result < 0 ) dol_print_error ( $db );
2014-02-23 20:10:05 +01:00
$selleruserevenustamp = $mysoc -> useRevenueStamp ();
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$totalpaye = $object -> getSommePaiement ();
2013-11-17 23:25:25 +01:00
$totalcreditnotes = $object -> getSumCreditNotesUsed ();
$totaldeposits = $object -> getSumDepositsUsed ();
2014-02-23 20:10:05 +01:00
// print "totalpaye=".$totalpaye." totalcreditnotes=".$totalcreditnotes." totaldeposts=".$totaldeposits."
// selleruserrevenuestamp=".$selleruserevenustamp;
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// We can also use bcadd to avoid pb with floating points
// For example print 239.2 - 229.3 - 9.9; does not return 0.
2014-02-23 20:10:05 +01:00
// $resteapayer=bcadd($object->total_ttc,$totalpaye,$conf->global->MAIN_MAX_DECIMALS_TOT);
// $resteapayer=bcadd($resteapayer,$totalavoir,$conf->global->MAIN_MAX_DECIMALS_TOT);
$resteapayer = price2num ( $object -> total_ttc - $totalpaye - $totalcreditnotes - $totaldeposits , 'MT' );
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
if ( $object -> paye )
2017-12-05 12:31:57 +01:00
{
2014-02-23 20:10:05 +01:00
$resteapayer = 0 ;
2017-12-05 12:31:57 +01:00
}
2014-02-23 20:10:05 +01:00
$resteapayeraffiche = $resteapayer ;
2014-03-01 19:45:13 +01:00
2017-10-13 01:03:33 +02:00
if ( ! empty ( $conf -> global -> FACTURE_DEPOSITS_ARE_JUST_PAYMENTS )) { // Never use this
2014-02-23 20:10:05 +01:00
$filterabsolutediscount = " fk_facture_source IS NULL " ; // If we want deposit to be substracted to payments only and not to total of final invoice
$filtercreditnote = " fk_facture_source IS NOT NULL " ; // If we want deposit to be substracted to payments only and not to total of final invoice
} else {
2018-02-19 17:32:59 +01:00
$filterabsolutediscount = " fk_facture_source IS NULL OR (description LIKE '(DEPOSIT)%' AND description NOT LIKE '(EXCESS RECEIVED)%') " ;
2017-10-13 01:03:33 +02:00
$filtercreditnote = " fk_facture_source IS NOT NULL AND (description NOT LIKE '(DEPOSIT)%' OR description LIKE '(EXCESS RECEIVED)%') " ;
2014-02-23 20:10:05 +01:00
}
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$absolute_discount = $soc -> getAvailableDiscounts ( '' , $filterabsolutediscount );
$absolute_creditnote = $soc -> getAvailableDiscounts ( '' , $filtercreditnote );
$absolute_discount = price2num ( $absolute_discount , 'MT' );
$absolute_creditnote = price2num ( $absolute_creditnote , 'MT' );
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
$author = new User ( $db );
2014-02-23 20:10:05 +01:00
if ( $object -> user_author ) {
2013-11-17 23:25:25 +01:00
$author -> fetch ( $object -> user_author );
}
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$objectidnext = $object -> getIdReplacingInvoice ();
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
$head = facture_prepare_head ( $object );
2014-03-01 19:45:13 +01:00
2017-03-20 20:58:43 +01:00
dol_fiche_head ( $head , 'compta' , $langs -> trans ( 'InvoiceCustomer' ), - 1 , 'bill' );
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$formconfirm = '' ;
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Confirmation de la conversion de l'avoir en reduc
2014-02-23 20:10:05 +01:00
if ( $action == 'converttoreduc' ) {
2017-10-13 01:03:33 +02:00
if ( $object -> type == Facture :: TYPE_STANDARD ) $type_fac = 'ExcessReceived' ;
elseif ( $object -> type == Facture :: TYPE_CREDIT_NOTE ) $type_fac = 'CreditNote' ;
elseif ( $object -> type == Facture :: TYPE_DEPOSIT ) $type_fac = 'Deposit' ;
2016-11-24 15:48:04 +01:00
$text = $langs -> trans ( 'ConfirmConvertToReduc' , strtolower ( $langs -> transnoentities ( $type_fac )));
2016-03-25 15:53:44 +01:00
$formconfirm = $form -> formconfirm ( $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id , $langs -> trans ( 'ConvertToReduc' ), $text , 'confirm_converttoreduc' , '' , " yes " , 2 );
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Confirmation to delete invoice
2014-02-23 20:10:05 +01:00
if ( $action == 'delete' ) {
$text = $langs -> trans ( 'ConfirmDeleteBill' , $object -> ref );
$formquestion = array ();
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$qualified_for_stock_change = 0 ;
if ( empty ( $conf -> global -> STOCK_SUPPORTS_SERVICES )) {
$qualified_for_stock_change = $object -> hasProductsOrServices ( 2 );
} else {
$qualified_for_stock_change = $object -> hasProductsOrServices ( 1 );
}
2014-03-01 19:45:13 +01:00
2016-03-11 15:42:14 +01:00
if ( $object -> type != Facture :: TYPE_DEPOSIT && ! empty ( $conf -> global -> STOCK_CALCULATE_ON_BILL ) && $qualified_for_stock_change && $object -> statut >= 1 )
2015-11-02 15:50:03 +01:00
{
2013-11-17 23:25:25 +01:00
$langs -> load ( " stocks " );
2014-02-23 20:10:05 +01:00
require_once DOL_DOCUMENT_ROOT . '/product/class/html.formproduct.class.php' ;
$formproduct = new FormProduct ( $db );
2014-02-26 01:03:26 +01:00
$label = $object -> type == Facture :: TYPE_CREDIT_NOTE ? $langs -> trans ( " SelectWarehouseForStockDecrease " ) : $langs -> trans ( " SelectWarehouseForStockIncrease " );
2018-06-28 12:05:02 +02:00
$forcecombo = 0 ;
if ( $conf -> browser -> name == 'ie' ) $forcecombo = 1 ; // There is a bug in IE10 that make combo inside popup crazy
2014-02-23 20:10:05 +01:00
$formquestion = array (
2018-06-28 12:05:02 +02:00
// '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' => 'other' , 'name' => 'idwarehouse' , 'label' => $label , 'value' => $formproduct -> selectWarehouses ( GETPOST ( 'idwarehouse' ) ? GETPOST ( 'idwarehouse' ) : 'ifone' , 'idwarehouse' , '' , 1 , 0 , 0 , $langs -> trans ( " NoStockAction " ), 0 , $forcecombo ))
);
2016-03-25 15:53:44 +01:00
$formconfirm = $form -> formconfirm ( $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id , $langs -> trans ( 'DeleteBill' ), $text , 'confirm_delete' , $formquestion , " yes " , 1 );
2014-02-23 20:10:05 +01:00
} else {
2018-03-31 23:39:08 +02:00
$formconfirm = $form -> formconfirm ( $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id , $langs -> trans ( 'DeleteBill' ), $text , 'confirm_delete' , '' , 'no' , 1 );
2014-02-23 20:10:05 +01:00
}
}
2014-03-01 19:45:13 +01:00
2018-04-03 17:34:20 +02:00
// Confirmation to remove invoice from cycle
if ( $action == 'situationout' ) {
$text = $langs -> trans ( 'ConfirmRemoveSituationFromCycle' , $object -> ref );
$label = $langs -> trans ( " ConfirmOuting " );
$formquestion = array ();
// remove situation from cycle
if ( $object -> statut == Facture :: STATUS_VALIDATED
2018-11-14 14:59:36 +01:00
&& $usercancreate
2018-04-03 17:34:20 +02:00
&& ! $objectidnext
&& $object -> is_last_in_cycle ()
2018-11-14 14:59:36 +01:00
&& $usercanunvalidate
2018-04-03 17:34:20 +02:00
)
{
$formconfirm = $form -> formconfirm ( $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id , $label , $text , 'confirm_situationout' , $formquestion , " yes " , 1 );
2018-04-09 09:17:26 +02:00
}
2018-04-03 17:34:20 +02:00
}
2014-03-01 19:45:13 +01:00
2018-01-29 16:21:54 +01:00
// Confirmation of validation
2015-01-31 00:08:45 +01:00
if ( $action == 'valid' )
{
2018-01-29 16:21:54 +01:00
// we check object has a draft number
2013-11-17 23:25:25 +01:00
$objectref = substr ( $object -> ref , 1 , 4 );
2014-02-23 20:10:05 +01:00
if ( $objectref == 'PROV' ) {
$savdate = $object -> date ;
if ( ! empty ( $conf -> global -> FAC_FORCE_DATE_VALIDATION )) {
$object -> date = dol_now ();
$object -> date_lim_reglement = $object -> calculate_date_lim_reglement ();
2013-04-20 00:10:20 +02:00
}
2013-11-17 23:25:25 +01:00
$numref = $object -> getNextNumRef ( $soc );
2014-02-23 20:10:05 +01:00
// $object->date=$savdate;
} else {
2013-11-17 23:25:25 +01:00
$numref = $object -> ref ;
}
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$text = $langs -> trans ( 'ConfirmValidateBill' , $numref );
if ( ! empty ( $conf -> notification -> enabled )) {
require_once DOL_DOCUMENT_ROOT . '/core/class/notify.class.php' ;
$notify = new Notify ( $db );
$text .= '<br>' ;
2015-03-18 21:44:57 +01:00
$text .= $notify -> confirmMessage ( 'BILL_VALIDATE' , $object -> socid , $object );
2014-02-23 20:10:05 +01:00
}
$formquestion = array ();
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$qualified_for_stock_change = 0 ;
if ( empty ( $conf -> global -> STOCK_SUPPORTS_SERVICES )) {
$qualified_for_stock_change = $object -> hasProductsOrServices ( 2 );
} else {
$qualified_for_stock_change = $object -> hasProductsOrServices ( 1 );
}
2014-03-01 19:45:13 +01:00
2015-01-31 00:08:45 +01:00
if ( $object -> type != Facture :: TYPE_DEPOSIT && ! empty ( $conf -> global -> STOCK_CALCULATE_ON_BILL ) && $qualified_for_stock_change )
{
2013-11-17 23:25:25 +01:00
$langs -> load ( " stocks " );
2014-02-23 20:10:05 +01:00
require_once DOL_DOCUMENT_ROOT . '/product/class/html.formproduct.class.php' ;
require_once DOL_DOCUMENT_ROOT . '/product/stock/class/entrepot.class.php' ;
$formproduct = new FormProduct ( $db );
2013-11-17 23:25:25 +01:00
$warehouse = new Entrepot ( $db );
$warehouse_array = $warehouse -> list_array ();
if ( count ( $warehouse_array ) == 1 ) {
2014-02-26 01:03:26 +01:00
$label = $object -> type == Facture :: TYPE_CREDIT_NOTE ? $langs -> trans ( " WarehouseForStockIncrease " , current ( $warehouse_array )) : $langs -> trans ( " WarehouseForStockDecrease " , current ( $warehouse_array ));
2013-11-17 23:25:25 +01:00
$value = '<input type="hidden" id="idwarehouse" name="idwarehouse" value="' . key ( $warehouse_array ) . '">' ;
} else {
2014-02-26 01:03:26 +01:00
$label = $object -> type == Facture :: TYPE_CREDIT_NOTE ? $langs -> trans ( " SelectWarehouseForStockIncrease " ) : $langs -> trans ( " SelectWarehouseForStockDecrease " );
2014-04-12 00:53:25 +02:00
$value = $formproduct -> selectWarehouses ( GETPOST ( 'idwarehouse' ) ? GETPOST ( 'idwarehouse' ) : 'ifone' , 'idwarehouse' , '' , 1 );
2013-04-20 00:10:20 +02:00
}
2014-02-23 20:10:05 +01:00
$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' => 'other' , 'name' => 'idwarehouse' , 'label' => $label , 'value' => $value ));
2013-11-17 23:25:25 +01:00
}
2014-02-26 01:03:26 +01:00
if ( $object -> type != Facture :: TYPE_CREDIT_NOTE && $object -> total_ttc < 0 ) // Can happen only if $conf->global->FACTURE_ENABLE_NEGATIVE is on
2013-11-17 23:25:25 +01:00
{
2014-02-23 20:10:05 +01:00
$text .= '<br>' . img_warning () . ' ' . $langs -> trans ( " ErrorInvoiceOfThisTypeMustBePositive " );
2013-11-17 23:25:25 +01:00
}
2016-03-25 15:53:44 +01:00
$formconfirm = $form -> formconfirm ( $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id , $langs -> trans ( 'ValidateBill' ), $text , 'confirm_valid' , $formquestion , (( $object -> type != Facture :: TYPE_CREDIT_NOTE && $object -> total_ttc < 0 ) ? " no " : " yes " ), 2 );
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Confirm back to draft status
2014-02-23 20:10:05 +01:00
if ( $action == 'modif' ) {
$text = $langs -> trans ( 'ConfirmUnvalidateBill' , $object -> ref );
$formquestion = array ();
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$qualified_for_stock_change = 0 ;
if ( empty ( $conf -> global -> STOCK_SUPPORTS_SERVICES )) {
$qualified_for_stock_change = $object -> hasProductsOrServices ( 2 );
} else {
$qualified_for_stock_change = $object -> hasProductsOrServices ( 1 );
}
2014-02-26 01:03:26 +01:00
if ( $object -> type != Facture :: TYPE_DEPOSIT && ! empty ( $conf -> global -> STOCK_CALCULATE_ON_BILL ) && $qualified_for_stock_change ) {
2013-11-17 23:25:25 +01:00
$langs -> load ( " stocks " );
2014-02-23 20:10:05 +01:00
require_once DOL_DOCUMENT_ROOT . '/product/class/html.formproduct.class.php' ;
require_once DOL_DOCUMENT_ROOT . '/product/stock/class/entrepot.class.php' ;
$formproduct = new FormProduct ( $db );
2013-11-17 23:25:25 +01:00
$warehouse = new Entrepot ( $db );
$warehouse_array = $warehouse -> list_array ();
if ( count ( $warehouse_array ) == 1 ) {
2014-02-26 01:03:26 +01:00
$label = $object -> type == Facture :: TYPE_CREDIT_NOTE ? $langs -> trans ( " WarehouseForStockDecrease " , current ( $warehouse_array )) : $langs -> trans ( " WarehouseForStockIncrease " , current ( $warehouse_array ));
2013-11-17 23:25:25 +01:00
$value = '<input type="hidden" id="idwarehouse" name="idwarehouse" value="' . key ( $warehouse_array ) . '">' ;
} else {
2014-02-26 01:03:26 +01:00
$label = $object -> type == Facture :: TYPE_CREDIT_NOTE ? $langs -> trans ( " SelectWarehouseForStockDecrease " ) : $langs -> trans ( " SelectWarehouseForStockIncrease " );
2014-04-12 00:53:25 +02:00
$value = $formproduct -> selectWarehouses ( GETPOST ( 'idwarehouse' ) ? GETPOST ( 'idwarehouse' ) : 'ifone' , 'idwarehouse' , '' , 1 );
2013-04-20 00:10:20 +02:00
}
2014-02-23 20:10:05 +01:00
$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' => 'other' , 'name' => 'idwarehouse' , 'label' => $label , 'value' => $value ));
2013-04-20 17:10:03 +02:00
}
2014-03-01 19:45:13 +01:00
2016-03-25 15:53:44 +01:00
$formconfirm = $form -> formconfirm ( $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id , $langs -> trans ( 'UnvalidateBill' ), $text , 'confirm_modif' , $formquestion , " yes " , 1 );
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Confirmation du classement paye
2014-02-23 20:10:05 +01:00
if ( $action == 'paid' && $resteapayer <= 0 ) {
2016-03-25 15:53:44 +01:00
$formconfirm = $form -> formconfirm ( $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id , $langs -> trans ( 'ClassifyPaid' ), $langs -> trans ( 'ConfirmClassifyPaidBill' , $object -> ref ), 'confirm_paid' , '' , " yes " , 1 );
2013-11-17 23:25:25 +01:00
}
2014-02-23 20:10:05 +01:00
if ( $action == 'paid' && $resteapayer > 0 ) {
2013-11-17 23:25:25 +01:00
// Code
2014-02-23 20:10:05 +01:00
$i = 0 ;
2018-03-31 23:39:08 +02:00
$close [ $i ][ 'code' ] = 'discount_vat' ; // escompte
2014-02-23 20:10:05 +01:00
$i ++ ;
2018-03-31 23:39:08 +02:00
$close [ $i ][ 'code' ] = 'badcustomer' ;
2014-02-23 20:10:05 +01:00
$i ++ ;
2013-11-17 23:25:25 +01:00
// Help
2014-02-23 20:10:05 +01:00
$i = 0 ;
2018-03-31 23:39:08 +02:00
$close [ $i ][ 'label' ] = $langs -> trans ( " HelpEscompte " ) . '<br><br>' . $langs -> trans ( " ConfirmClassifyPaidPartiallyReasonDiscountVatDesc " );
2014-02-23 20:10:05 +01:00
$i ++ ;
2018-03-31 23:39:08 +02:00
$close [ $i ][ 'label' ] = $langs -> trans ( " ConfirmClassifyPaidPartiallyReasonBadCustomerDesc " );
2014-02-23 20:10:05 +01:00
$i ++ ;
2013-11-17 23:25:25 +01:00
// Texte
2014-02-23 20:10:05 +01:00
$i = 0 ;
2018-03-31 23:39:08 +02:00
$close [ $i ][ 'reason' ] = $form -> textwithpicto ( $langs -> transnoentities ( " ConfirmClassifyPaidPartiallyReasonDiscount " , $resteapayer , $langs -> trans ( " Currency " . $conf -> currency )), $close [ $i ][ 'label' ], 1 );
2014-02-23 20:10:05 +01:00
$i ++ ;
2018-03-31 23:39:08 +02:00
$close [ $i ][ 'reason' ] = $form -> textwithpicto ( $langs -> transnoentities ( " ConfirmClassifyPaidPartiallyReasonBadCustomer " , $resteapayer , $langs -> trans ( " Currency " . $conf -> currency )), $close [ $i ][ 'label' ], 1 );
2014-02-23 20:10:05 +01:00
$i ++ ;
2013-11-17 23:25:25 +01:00
// arrayreasons[code]=reason
2014-02-23 20:10:05 +01:00
foreach ( $close as $key => $val ) {
2018-03-31 23:39:08 +02:00
$arrayreasons [ $close [ $key ][ 'code' ]] = $close [ $key ][ 'reason' ];
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Cree un tableau formulaire
2018-03-31 23:39:08 +02:00
$formquestion = array ( 'text' => $langs -> trans ( " ConfirmClassifyPaidPartiallyQuestion " ), array ( 'type' => 'radio' , 'name' => 'close_code' , 'label' => $langs -> trans ( " Reason " ), 'values' => $arrayreasons ), array ( 'type' => 'text' , 'name' => 'close_note' , 'label' => $langs -> trans ( " Comment " ), 'value' => '' , 'morecss' => 'minwidth300' ));
2013-11-17 23:25:25 +01:00
// Paiement incomplet. On demande si motif = escompte ou autre
2018-05-29 10:57:14 +02:00
$formconfirm = $form -> formconfirm ( $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id , $langs -> trans ( 'ClassifyPaid' ), $langs -> trans ( 'ConfirmClassifyPaidPartially' , $object -> ref ), 'confirm_paid_partially' , $formquestion , " yes " , 1 , 310 );
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Confirmation du classement abandonne
2014-02-23 20:10:05 +01:00
if ( $action == 'canceled' ) {
2013-11-17 23:25:25 +01:00
// S'il y a une facture de remplacement pas encore validee (etat brouillon),
// on ne permet pas de classer abandonner la facture.
2014-02-23 20:10:05 +01:00
if ( $objectidnext ) {
$facturereplacement = new Facture ( $db );
2013-11-17 23:25:25 +01:00
$facturereplacement -> fetch ( $objectidnext );
2014-02-23 20:10:05 +01:00
$statusreplacement = $facturereplacement -> statut ;
2013-04-20 17:10:03 +02:00
}
2014-02-23 20:10:05 +01:00
if ( $objectidnext && $statusreplacement == 0 ) {
print '<div class="error">' . $langs -> trans ( " ErrorCantCancelIfReplacementInvoiceNotValidated " ) . '</div>' ;
} else {
2013-04-20 17:10:03 +02:00
// Code
2014-02-23 20:10:05 +01:00
$close [ 1 ] [ 'code' ] = 'badcustomer' ;
$close [ 2 ] [ 'code' ] = 'abandon' ;
2013-04-20 17:10:03 +02:00
// Help
2014-02-23 20:10:05 +01:00
$close [ 1 ] [ 'label' ] = $langs -> trans ( " ConfirmClassifyPaidPartiallyReasonBadCustomerDesc " );
$close [ 2 ] [ 'label' ] = $langs -> trans ( " ConfirmClassifyAbandonReasonOtherDesc " );
2013-04-20 17:10:03 +02:00
// Texte
2016-03-25 15:24:57 +01:00
$close [ 1 ] [ 'reason' ] = $form -> textwithpicto ( $langs -> transnoentities ( " ConfirmClassifyPaidPartiallyReasonBadCustomer " , $object -> ref ), $close [ 1 ] [ 'label' ], 1 );
$close [ 2 ] [ 'reason' ] = $form -> textwithpicto ( $langs -> transnoentities ( " ConfirmClassifyAbandonReasonOther " ), $close [ 2 ] [ 'label' ], 1 );
2013-11-17 23:25:25 +01:00
// arrayreasons
2014-02-23 20:10:05 +01:00
$arrayreasons [ $close [ 1 ] [ 'code' ]] = $close [ 1 ] [ 'reason' ];
$arrayreasons [ $close [ 2 ] [ 'code' ]] = $close [ 2 ] [ 'reason' ];
2014-03-01 19:45:13 +01:00
2013-04-20 17:10:03 +02:00
// Cree un tableau formulaire
2018-03-31 23:39:08 +02:00
$formquestion = array ( 'text' => $langs -> trans ( " ConfirmCancelBillQuestion " ), array ( 'type' => 'radio' , 'name' => 'close_code' , 'label' => $langs -> trans ( " Reason " ), 'values' => $arrayreasons ), array ( 'type' => 'text' , 'name' => 'close_note' , 'label' => $langs -> trans ( " Comment " ), 'value' => '' , 'morecss' => 'minwidth300' ));
2014-03-01 19:45:13 +01:00
2018-03-31 23:39:08 +02:00
$formconfirm = $form -> formconfirm ( $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id , $langs -> trans ( 'CancelBill' ), $langs -> trans ( 'ConfirmCancelBill' , $object -> ref ), 'confirm_canceled' , $formquestion , " yes " , 1 , 250 );
2013-04-20 17:10:03 +02:00
}
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2017-12-03 11:59:16 +01:00
if ( $action == 'deletepaiement' )
{
$payment_id = GETPOST ( 'paiement_id' );
2018-03-31 23:39:08 +02:00
$formconfirm = $form -> formconfirm ( $_SERVER [ " PHP_SELF " ] . '?id=' . $object -> id . '&paiement_id=' . $payment_id , $langs -> trans ( 'DeletePayment' ), $langs -> trans ( 'ConfirmDeletePayment' ), 'confirm_delete_paiement' , '' , 'no' , 1 );
2017-12-03 11:59:16 +01:00
}
2013-11-17 23:25:25 +01:00
// Confirmation de la suppression d'une ligne produit
2014-02-23 20:10:05 +01:00
if ( $action == 'ask_deleteline' ) {
2016-03-25 15:53:44 +01:00
$formconfirm = $form -> formconfirm ( $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id . '&lineid=' . $lineid , $langs -> trans ( 'DeleteProductLine' ), $langs -> trans ( 'ConfirmDeleteProductLine' ), 'confirm_deleteline' , '' , 'no' , 1 );
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Clone confirmation
2016-03-11 15:42:14 +01:00
if ( $action == 'clone' )
2015-11-02 15:50:03 +01:00
{
2013-11-17 23:25:25 +01:00
// Create an array for form
2014-02-23 20:10:05 +01:00
$formquestion = array (
// 'text' => $langs->trans("ConfirmClone"),
// array('type' => 'checkbox', 'name' => 'clone_content', 'label' => $langs->trans("CloneMainAttributes"), 'value' => 1)
2015-11-02 15:50:03 +01:00
array ( 'type' => 'other' , 'name' => 'socid' , 'label' => $langs -> trans ( " SelectThirdParty " ), 'value' => $form -> select_company ( $object -> socid , 'socid' , '(s.client=1 OR s.client=2 OR s.client=3)' , 1 )));
2013-11-17 23:25:25 +01:00
// Paiement incomplet. On demande si motif = escompte ou autre
2016-03-25 15:53:44 +01:00
$formconfirm = $form -> formconfirm ( $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id , $langs -> trans ( 'CloneInvoice' ), $langs -> trans ( 'ConfirmCloneInvoice' , $object -> ref ), 'confirm_clone' , $formquestion , 'yes' , 1 );
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2018-08-30 11:27:48 +02:00
// Call Hook formConfirm
$parameters = array ( 'lineid' => $lineid );
$reshook = $hookmanager -> executeHooks ( 'formConfirm' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
if ( empty ( $reshook )) $formconfirm .= $hookmanager -> resPrint ;
elseif ( $reshook > 0 ) $formconfirm = $hookmanager -> resPrint ;
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Print form confirm
print $formconfirm ;
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Invoice content
2014-03-01 19:45:13 +01:00
2018-02-20 10:05:11 +01:00
$linkback = '<a href="' . DOL_URL_ROOT . '/compta/facture/list.php?restore_lastsearch_values=1' . ( ! empty ( $socid ) ? '&socid=' . $socid : '' ) . '">' . $langs -> trans ( " BackToList " ) . '</a>' ;
2016-09-29 07:01:58 +02:00
2016-09-21 01:25:34 +02:00
$morehtmlref = '<div class="refidno">' ;
// Ref customer
2018-11-14 14:59:36 +01:00
$morehtmlref .= $form -> editfieldkey ( " RefCustomer " , 'ref_client' , $object -> ref_client , $object , $usercancreate , 'string' , '' , 0 , 1 );
$morehtmlref .= $form -> editfieldval ( " RefCustomer " , 'ref_client' , $object -> ref_client , $object , $usercancreate , 'string' , '' , null , null , '' , 1 );
2016-09-21 01:25:34 +02:00
// Thirdparty
2018-03-09 22:36:00 +01:00
$morehtmlref .= '<br>' . $langs -> trans ( 'ThirdParty' ) . ' : ' . $object -> thirdparty -> getNomUrl ( 1 , 'customer' );
2018-09-16 12:27:56 +02:00
if ( empty ( $conf -> global -> MAIN_DISABLE_OTHER_LINK ) && $object -> thirdparty -> id > 0 ) $morehtmlref .= ' (<a href="' . DOL_URL_ROOT . '/compta/facture/list.php?socid=' . $object -> thirdparty -> id . '&search_societe=' . urlencode ( $object -> thirdparty -> name ) . '">' . $langs -> trans ( " OtherBills " ) . '</a>)' ;
2016-09-21 01:25:34 +02:00
// Project
if ( ! empty ( $conf -> projet -> enabled ))
{
2017-10-16 08:47:05 +02:00
$langs -> load ( " projects " );
$morehtmlref .= '<br>' . $langs -> trans ( 'Project' ) . ' ' ;
2018-11-14 14:59:36 +01:00
if ( $usercancreate )
2017-10-16 08:47:05 +02:00
{
if ( $action != 'classify' )
$morehtmlref .= '<a href="' . $_SERVER [ 'PHP_SELF' ] . '?action=classify&id=' . $object -> id . '">' . img_edit ( $langs -> transnoentitiesnoconv ( 'SetProject' )) . '</a> : ' ;
if ( $action == 'classify' ) {
//$morehtmlref.=$form->form_project($_SERVER['PHP_SELF'] . '?id=' . $object->id, $object->socid, $object->fk_project, 'projectid', 0, 0, 1, 1);
$morehtmlref .= '<form method="post" action="' . $_SERVER [ 'PHP_SELF' ] . '?id=' . $object -> id . '">' ;
$morehtmlref .= '<input type="hidden" name="action" value="classin">' ;
$morehtmlref .= '<input type="hidden" name="token" value="' . $_SESSION [ 'newtoken' ] . '">' ;
$morehtmlref .= $formproject -> select_projects ( $object -> socid , $object -> fk_project , 'projectid' , $maxlength , 0 , 1 , 0 , 1 , 0 , 0 , '' , 1 );
$morehtmlref .= '<input type="submit" class="button valignmiddle" value="' . $langs -> trans ( " Modify " ) . '">' ;
$morehtmlref .= '</form>' ;
} else {
$morehtmlref .= $form -> form_project ( $_SERVER [ 'PHP_SELF' ] . '?id=' . $object -> id , $object -> socid , $object -> fk_project , 'none' , 0 , 0 , 0 , 1 );
}
} else {
if ( ! empty ( $object -> fk_project )) {
$proj = new Project ( $db );
$proj -> fetch ( $object -> fk_project );
$morehtmlref .= '<a href="' . DOL_URL_ROOT . '/projet/card.php?id=' . $object -> fk_project . '" title="' . $langs -> trans ( 'ShowProject' ) . '">' ;
$morehtmlref .= $proj -> ref ;
$morehtmlref .= '</a>' ;
} else {
$morehtmlref .= '' ;
}
}
2016-09-21 01:25:34 +02:00
}
$morehtmlref .= '</div>' ;
2016-10-29 07:45:24 +02:00
2016-09-26 00:10:29 +02:00
$object -> totalpaye = $totalpaye ; // To give a chance to dol_banner_tab to use already paid amount to show correct status
2016-10-29 07:45:24 +02:00
2018-12-02 14:31:45 +01:00
dol_banner_tab ( $object , 'ref' , $linkback , 1 , 'ref' , 'ref' , $morehtmlref , '' , 0 , '' , '' );
2016-10-29 07:45:24 +02:00
2016-09-21 01:25:34 +02:00
print '<div class="fichecenter">' ;
print '<div class="fichehalfleft">' ;
print '<div class="underbanner clearboth"></div>' ;
2016-10-29 07:45:24 +02:00
2016-09-21 01:25:34 +02:00
print '<table class="border" width="100%">' ;
2016-10-29 07:45:24 +02:00
2013-11-17 23:25:25 +01:00
// Type
2016-09-21 01:25:34 +02:00
print '<tr><td class="titlefield">' . $langs -> trans ( 'Type' ) . '</td><td>' ;
2013-11-17 23:25:25 +01:00
print $object -> getLibType ();
2014-02-26 01:03:26 +01:00
if ( $object -> type == Facture :: TYPE_REPLACEMENT ) {
2014-02-23 20:10:05 +01:00
$facreplaced = new Facture ( $db );
2013-11-17 23:25:25 +01:00
$facreplaced -> fetch ( $object -> fk_facture_source );
2014-02-23 20:10:05 +01:00
print ' (' . $langs -> transnoentities ( " ReplaceInvoice " , $facreplaced -> getNomUrl ( 1 )) . ')' ;
2013-11-17 23:25:25 +01:00
}
2015-07-08 14:32:57 +02:00
if ( $object -> type == Facture :: TYPE_CREDIT_NOTE && ! empty ( $object -> fk_facture_source )) {
2014-02-23 20:10:05 +01:00
$facusing = new Facture ( $db );
2013-11-17 23:25:25 +01:00
$facusing -> fetch ( $object -> fk_facture_source );
2014-02-23 20:10:05 +01:00
print ' (' . $langs -> transnoentities ( " CorrectInvoice " , $facusing -> getNomUrl ( 1 )) . ')' ;
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$facidavoir = $object -> getListIdAvoirFromInvoice ();
if ( count ( $facidavoir ) > 0 ) {
print ' (' . $langs -> transnoentities ( " InvoiceHasAvoir " );
$i = 0 ;
foreach ( $facidavoir as $id ) {
if ( $i == 0 )
print ' ' ;
else
print ',' ;
$facavoir = new Facture ( $db );
2013-11-17 23:25:25 +01:00
$facavoir -> fetch ( $id );
print $facavoir -> getNomUrl ( 1 );
2013-04-20 17:10:03 +02:00
}
2013-11-17 23:25:25 +01:00
print ')' ;
}
2014-02-23 20:10:05 +01:00
if ( $objectidnext > 0 ) {
$facthatreplace = new Facture ( $db );
2013-11-17 23:25:25 +01:00
$facthatreplace -> fetch ( $objectidnext );
2014-02-23 20:10:05 +01:00
print ' (' . $langs -> transnoentities ( " ReplacedByInvoice " , $facthatreplace -> getNomUrl ( 1 )) . ')' ;
2013-11-17 23:25:25 +01:00
}
2017-09-11 15:04:29 +02:00
if ( $object -> type == Facture :: TYPE_CREDIT_NOTE || $object -> type == Facture :: TYPE_DEPOSIT ) {
$discount = new DiscountAbsolute ( $db );
$result = $discount -> fetch ( 0 , $object -> id );
if ( $result > 0 ){
2018-08-29 11:47:20 +02:00
print '. ' . $langs -> trans ( " CreditNoteConvertedIntoDiscount " , $object -> getLibType ( 1 ), $discount -> getNomUrl ( 1 , 'discount' )) . '<br>' ;
2017-09-11 15:04:29 +02:00
}
}
2013-11-17 23:25:25 +01:00
print '</td></tr>' ;
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Relative and absolute discounts
2017-05-09 18:15:50 +02:00
print '<!-- Discounts --><tr><td>' . $langs -> trans ( 'Discounts' );
2018-03-02 16:48:25 +01:00
2016-09-21 01:25:34 +02:00
print '</td><td>' ;
2018-03-02 16:48:25 +01:00
$thirdparty = $soc ;
$discount_type = 0 ;
$backtopage = urlencode ( $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id );
include DOL_DOCUMENT_ROOT . '/core/tpl/object_discounts.tpl.php' ;
2013-11-17 23:25:25 +01:00
print '</td></tr>' ;
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Date invoice
print '<tr><td>' ;
print '<table class="nobordernopadding" width="100%"><tr><td>' ;
2016-08-31 06:27:35 +02:00
print $langs -> trans ( 'DateInvoice' );
2013-11-17 23:25:25 +01:00
print '</td>' ;
2018-11-14 14:59:36 +01:00
if ( $object -> type != Facture :: TYPE_CREDIT_NOTE && $action != 'editinvoicedate' && ! empty ( $object -> brouillon ) && $usercancreate && empty ( $conf -> global -> FAC_FORCE_DATE_VALIDATION ))
2014-05-12 12:10:52 +02:00
print '<td align="right"><a href="' . $_SERVER [ " PHP_SELF " ] . '?action=editinvoicedate&facid=' . $object -> id . '">' . img_edit ( $langs -> trans ( 'SetDate' ), 1 ) . '</a></td>' ;
2013-11-17 23:25:25 +01:00
print '</tr></table>' ;
2016-09-21 01:25:34 +02:00
print '</td><td>' ;
2014-03-01 19:45:13 +01:00
2014-02-26 01:03:26 +01:00
if ( $object -> type != Facture :: TYPE_CREDIT_NOTE ) {
2014-02-23 20:10:05 +01:00
if ( $action == 'editinvoicedate' ) {
2016-03-25 15:53:44 +01:00
$form -> form_date ( $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id , $object -> date , 'invoicedate' );
2014-02-23 20:10:05 +01:00
} else {
2016-09-10 17:43:28 +02:00
print dol_print_date ( $object -> date , 'day' );
2013-04-20 17:10:03 +02:00
}
2014-02-23 20:10:05 +01:00
} else {
2016-09-10 17:43:28 +02:00
print dol_print_date ( $object -> date , 'day' );
2013-11-17 23:25:25 +01:00
}
print '</td>' ;
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
print '</tr>' ;
2014-03-01 19:45:13 +01:00
2016-05-29 23:56:58 +02:00
if ( ! empty ( $conf -> global -> INVOICE_POINTOFTAX_DATE ))
{
// Date invoice
print '<tr><td>' ;
print '<table class="nobordernopadding" width="100%"><tr><td>' ;
print $langs -> trans ( 'DatePointOfTax' );
print '</td>' ;
print '<td align="right"><a href="' . $_SERVER [ " PHP_SELF " ] . '?action=editdate_pointoftax&facid=' . $object -> id . '">' . img_edit ( $langs -> trans ( 'SetDate' ), 1 ) . '</a></td>' ;
print '</tr></table>' ;
2016-09-21 01:25:34 +02:00
print '</td><td>' ;
2016-05-29 23:56:58 +02:00
if ( $action == 'editdate_pointoftax' ) {
$form -> form_date ( $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id , $object -> date_pointoftax , 'date_pointoftax' );
} else {
2016-09-10 17:43:28 +02:00
print dol_print_date ( $object -> date_pointoftax , 'day' );
2016-05-29 23:56:58 +02:00
}
print '</td></tr>' ;
2016-08-10 09:47:25 +02:00
}
2016-05-29 23:56:58 +02:00
2016-10-24 03:23:40 +02:00
// Payment term
2013-11-17 23:25:25 +01:00
print '<tr><td>' ;
print '<table class="nobordernopadding" width="100%"><tr><td>' ;
print $langs -> trans ( 'PaymentConditionsShort' );
print '</td>' ;
2018-11-14 14:59:36 +01:00
if ( $object -> type != Facture :: TYPE_CREDIT_NOTE && $action != 'editconditions' && $usercancreate )
2014-05-12 12:10:52 +02:00
print '<td align="right"><a href="' . $_SERVER [ " PHP_SELF " ] . '?action=editconditions&facid=' . $object -> id . '">' . img_edit ( $langs -> trans ( 'SetConditions' ), 1 ) . '</a></td>' ;
2013-11-17 23:25:25 +01:00
print '</tr></table>' ;
2016-09-21 01:25:34 +02:00
print '</td><td>' ;
2015-04-27 02:33:44 +02:00
if ( $object -> type != Facture :: TYPE_CREDIT_NOTE )
{
2014-02-23 20:10:05 +01:00
if ( $action == 'editconditions' ) {
2014-05-12 12:10:52 +02:00
$form -> form_conditions_reglement ( $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id , $object -> cond_reglement_id , 'cond_reglement_id' );
2014-02-23 20:10:05 +01:00
} else {
2014-05-12 12:10:52 +02:00
$form -> form_conditions_reglement ( $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id , $object -> cond_reglement_id , 'none' );
2013-11-17 23:25:25 +01:00
}
2014-02-23 20:10:05 +01:00
} else {
2013-11-17 23:25:25 +01:00
print ' ' ;
}
print '</td></tr>' ;
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Date payment term
print '<tr><td>' ;
print '<table class="nobordernopadding" width="100%"><tr><td>' ;
print $langs -> trans ( 'DateMaxPayment' );
print '</td>' ;
2018-11-14 14:59:36 +01:00
if ( $object -> type != Facture :: TYPE_CREDIT_NOTE && $action != 'editpaymentterm' && $usercancreate )
2014-05-12 12:10:52 +02:00
print '<td align="right"><a href="' . $_SERVER [ " PHP_SELF " ] . '?action=editpaymentterm&facid=' . $object -> id . '">' . img_edit ( $langs -> trans ( 'SetDate' ), 1 ) . '</a></td>' ;
2013-11-17 23:25:25 +01:00
print '</tr></table>' ;
2016-09-21 01:25:34 +02:00
print '</td><td>' ;
2015-04-27 02:33:44 +02:00
if ( $object -> type != Facture :: TYPE_CREDIT_NOTE )
{
2014-02-23 20:10:05 +01:00
if ( $action == 'editpaymentterm' ) {
2016-03-25 15:53:44 +01:00
$form -> form_date ( $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id , $object -> date_lim_reglement , 'paymentterm' );
2014-02-23 20:10:05 +01:00
} else {
2016-09-10 17:43:28 +02:00
print dol_print_date ( $object -> date_lim_reglement , 'day' );
2015-09-05 10:56:13 +02:00
if ( $object -> hasDelay ()) {
2014-02-23 20:10:05 +01:00
print img_warning ( $langs -> trans ( 'Late' ));
2015-09-05 10:56:13 +02:00
}
2014-02-23 20:10:05 +01:00
}
} else {
2013-11-17 23:25:25 +01:00
print ' ' ;
}
print '</td></tr>' ;
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Payment mode
print '<tr><td>' ;
print '<table class="nobordernopadding" width="100%"><tr><td>' ;
print $langs -> trans ( 'PaymentMode' );
print '</td>' ;
2018-11-14 14:59:36 +01:00
if ( $action != 'editmode' && $usercancreate )
2014-05-12 12:10:52 +02:00
print '<td align="right"><a href="' . $_SERVER [ " PHP_SELF " ] . '?action=editmode&facid=' . $object -> id . '">' . img_edit ( $langs -> trans ( 'SetMode' ), 1 ) . '</a></td>' ;
2013-11-17 23:25:25 +01:00
print '</tr></table>' ;
2016-09-21 01:25:34 +02:00
print '</td><td>' ;
2014-09-07 12:22:04 +02:00
if ( $action == 'editmode' )
{
$form -> form_modes_reglement ( $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id , $object -> mode_reglement_id , 'mode_reglement_id' , 'CRDT' );
}
else
{
$form -> form_modes_reglement ( $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id , $object -> mode_reglement_id , 'none' , 'CRDT' );
2013-11-17 23:25:25 +01:00
}
print '</td></tr>' ;
2014-07-07 17:59:04 +02:00
2016-01-23 16:01:55 +01:00
// Multicurrency
if ( ! empty ( $conf -> multicurrency -> enabled ))
{
// Multicurrency code
print '<tr>' ;
2016-02-15 00:58:51 +01:00
print '<td>' ;
2016-01-23 16:01:55 +01:00
print '<table class="nobordernopadding" width="100%"><tr><td>' ;
2018-10-27 17:45:29 +02:00
print $form -> editfieldkey ( 'Currency' , 'multicurrency_code' , '' , $object , 0 );
2016-01-23 16:01:55 +01:00
print '</td>' ;
2018-11-15 09:40:08 +01:00
if ( $usercancreate && $action != 'editmulticurrencycode' && ! empty ( $object -> brouillon ))
2016-01-23 16:01:55 +01:00
print '<td align="right"><a href="' . $_SERVER [ " PHP_SELF " ] . '?action=editmulticurrencycode&id=' . $object -> id . '">' . img_edit ( $langs -> transnoentitiesnoconv ( 'SetMultiCurrencyCode' ), 1 ) . '</a></td>' ;
print '</tr></table>' ;
2016-09-21 01:25:34 +02:00
print '</td><td>' ;
2018-11-15 09:40:08 +01:00
$htmlname = (( $usercancreate && $action == 'editmulticurrencycode' ) ? 'multicurrency_code' : 'none' );
$form -> form_multicurrency_code ( $_SERVER [ 'PHP_SELF' ] . '?id=' . $object -> id , $object -> multicurrency_code , $htmlname );
2016-01-23 16:01:55 +01:00
print '</td></tr>' ;
2016-08-10 09:47:25 +02:00
2017-04-12 11:30:33 +02:00
print '<tr>' ;
print '<td>' ;
print '<table class="nobordernopadding" width="100%"><tr><td>' ;
2018-10-27 17:45:29 +02:00
print $form -> editfieldkey ( 'CurrencyRate' , 'multicurrency_tx' , '' , $object , 0 );
2017-04-12 11:30:33 +02:00
print '</td>' ;
2018-11-15 09:40:08 +01:00
if ( $usercancreate && $action != 'editmulticurrencyrate' && ! empty ( $object -> brouillon ) && $object -> multicurrency_code && $object -> multicurrency_code != $conf -> currency )
2017-04-12 11:30:33 +02:00
print '<td align="right"><a href="' . $_SERVER [ " PHP_SELF " ] . '?action=editmulticurrencyrate&id=' . $object -> id . '">' . img_edit ( $langs -> transnoentitiesnoconv ( 'SetMultiCurrencyCode' ), 1 ) . '</a></td>' ;
print '</tr></table>' ;
print '</td><td>' ;
if ( $action == 'editmulticurrencyrate' || $action == 'actualizemulticurrencyrate' ) {
if ( $action == 'actualizemulticurrencyrate' ) {
list ( $object -> fk_multicurrency , $object -> multicurrency_tx ) = MultiCurrency :: getIdAndTxFromCode ( $object -> db , $object -> multicurrency_code );
}
2018-11-15 09:40:08 +01:00
$form -> form_multicurrency_rate ( $_SERVER [ 'PHP_SELF' ] . '?id=' . $object -> id , $object -> multicurrency_tx , ( $usercancreate ? 'multicurrency_tx' : 'none' ), $object -> multicurrency_code );
2017-04-12 11:30:33 +02:00
} else {
$form -> form_multicurrency_rate ( $_SERVER [ 'PHP_SELF' ] . '?id=' . $object -> id , $object -> multicurrency_tx , 'none' , $object -> multicurrency_code );
if ( $object -> statut == $object :: STATUS_DRAFT && $object -> multicurrency_code && $object -> multicurrency_code != $conf -> currency ) {
print '<div class="inline-block"> ' ;
print '<a href="' . $_SERVER [ " PHP_SELF " ] . '?id=' . $object -> id . '&action=actualizemulticurrencyrate">' . $langs -> trans ( " ActualizeCurrency " ) . '</a>' ;
print '</div>' ;
}
}
print '</td></tr>' ;
2016-01-23 16:01:55 +01:00
}
2014-07-07 17:59:04 +02:00
// Bank Account
print '<tr><td class="nowrap">' ;
print '<table width="100%" class="nobordernopadding"><tr><td class="nowrap">' ;
print $langs -> trans ( 'BankAccount' );
print '<td>' ;
2018-11-14 14:59:36 +01:00
if (( $action != 'editbankaccount' ) && $usercancreate )
2017-10-16 08:47:05 +02:00
print '<td align="right"><a href="' . $_SERVER [ " PHP_SELF " ] . '?action=editbankaccount&id=' . $object -> id . '">' . img_edit ( $langs -> trans ( 'SetBankAccount' ), 1 ) . '</a></td>' ;
2014-07-07 17:59:04 +02:00
print '</tr></table>' ;
2016-09-21 01:25:34 +02:00
print '</td><td>' ;
2014-07-07 17:59:04 +02:00
if ( $action == 'editbankaccount' )
{
2017-10-16 08:47:05 +02:00
$form -> formSelectAccount ( $_SERVER [ 'PHP_SELF' ] . '?id=' . $object -> id , $object -> fk_account , 'fk_account' , 1 );
2014-07-07 17:59:04 +02:00
}
else
{
2017-10-16 08:47:05 +02:00
$form -> formSelectAccount ( $_SERVER [ 'PHP_SELF' ] . '?id=' . $object -> id , $object -> fk_account , 'none' );
2014-07-07 17:59:04 +02:00
}
print " </td> " ;
print '</tr>' ;
2014-03-01 19:45:13 +01:00
2014-11-14 16:43:49 +01:00
2017-06-14 10:48:34 +02:00
2015-04-27 02:33:44 +02:00
2015-01-25 21:32:40 +01:00
2015-02-23 09:16:14 +01:00
// Incoterms
if ( ! empty ( $conf -> incoterm -> enabled ))
2015-03-18 14:31:37 +01:00
{
2015-02-23 09:16:14 +01:00
print '<tr><td>' ;
2017-10-16 08:47:05 +02:00
print '<table width="100%" class="nobordernopadding"><tr><td>' ;
print $langs -> trans ( 'IncotermLabel' );
print '<td><td align="right">' ;
2018-11-14 14:59:36 +01:00
if ( $usercancreate ) print '<a href="' . DOL_URL_ROOT . '/compta/facture/card.php?facid=' . $object -> id . '&action=editincoterm">' . img_edit () . '</a>' ;
2017-10-16 08:47:05 +02:00
else print ' ' ;
print '</td></tr></table>' ;
print '</td>' ;
print '<td>' ;
2015-02-23 09:16:14 +01:00
if ( $action != 'editincoterm' )
{
2016-03-25 15:24:57 +01:00
print $form -> textwithpicto ( $object -> display_incoterms (), $object -> libelle_incoterms , 1 );
2015-02-23 09:16:14 +01:00
}
2015-03-18 14:31:37 +01:00
else
2015-02-23 09:16:14 +01:00
{
print $form -> select_incoterms (( ! empty ( $object -> fk_incoterms ) ? $object -> fk_incoterms : '' ), ( ! empty ( $object -> location_incoterms ) ? $object -> location_incoterms : '' ), $_SERVER [ 'PHP_SELF' ] . '?id=' . $object -> id );
}
2017-10-16 08:47:05 +02:00
print '</td></tr>' ;
2015-02-23 09:16:14 +01:00
}
2014-03-01 19:45:13 +01:00
2014-10-14 17:00:06 +02:00
// Other attributes
2016-09-21 01:25:34 +02:00
$cols = 2 ;
2014-10-14 17:00:06 +02:00
include DOL_DOCUMENT_ROOT . '/core/tpl/extrafields_view.tpl.php' ;
2014-03-01 19:45:13 +01:00
2016-09-21 01:25:34 +02:00
print '</table>' ;
2016-10-29 07:45:24 +02:00
2016-09-21 01:25:34 +02:00
print '</div>' ;
print '<div class="fichehalfright">' ;
print '<div class="ficheaddleft">' ;
print '<div class="underbanner clearboth"></div>' ;
2017-06-07 16:44:04 +02:00
2016-09-21 01:25:34 +02:00
print '<table class="border centpercent">' ;
2017-06-07 16:44:04 +02:00
2016-10-24 03:23:40 +02:00
if ( ! empty ( $conf -> multicurrency -> enabled ) && ( $object -> multicurrency_code != $conf -> currency ))
{
2017-10-16 08:47:05 +02:00
// Multicurrency Amount HT
2018-10-27 17:45:29 +02:00
print '<tr><td class="titlefieldmiddle">' . $form -> editfieldkey ( 'MulticurrencyAmountHT' , 'multicurrency_total_ht' , '' , $object , 0 ) . '</td>' ;
2017-10-16 08:47:05 +02:00
print '<td class="nowrap amountcard">' . price ( $object -> multicurrency_total_ht , '' , $langs , 0 , - 1 , - 1 , ( ! empty ( $object -> multicurrency_code ) ? $object -> multicurrency_code : $conf -> currency )) . '</td>' ;
print '</tr>' ;
// Multicurrency Amount VAT
2018-10-27 17:45:29 +02:00
print '<tr><td>' . $form -> editfieldkey ( 'MulticurrencyAmountVAT' , 'multicurrency_total_tva' , '' , $object , 0 ) . '</td>' ;
2017-10-16 08:47:05 +02:00
print '<td class="nowrap amountcard">' . price ( $object -> multicurrency_total_tva , '' , $langs , 0 , - 1 , - 1 , ( ! empty ( $object -> multicurrency_code ) ? $object -> multicurrency_code : $conf -> currency )) . '</td>' ;
print '</tr>' ;
// Multicurrency Amount TTC
2018-10-27 17:45:29 +02:00
print '<tr><td>' . $form -> editfieldkey ( 'MulticurrencyAmountTTC' , 'multicurrency_total_ttc' , '' , $object , 0 ) . '</td>' ;
2017-10-16 08:47:05 +02:00
print '<td class="nowrap amountcard">' . price ( $object -> multicurrency_total_ttc , '' , $langs , 0 , - 1 , - 1 , ( ! empty ( $object -> multicurrency_code ) ? $object -> multicurrency_code : $conf -> currency )) . '</td>' ;
print '</tr>' ;
2016-10-24 03:23:40 +02:00
}
2016-10-29 07:45:24 +02:00
2016-09-21 01:25:34 +02:00
// Amount
2017-04-12 11:30:33 +02:00
print '<tr><td class="titlefieldmiddle">' . $langs -> trans ( 'AmountHT' ) . '</td>' ;
print '<td class="nowrap amountcard">' . price ( $object -> total_ht , 1 , '' , 1 , - 1 , - 1 , $conf -> currency ) . '</td></tr>' ;
2016-10-29 07:45:24 +02:00
2016-10-24 03:23:40 +02:00
// Vat
2017-04-12 11:30:33 +02:00
print '<tr><td>' . $langs -> trans ( 'AmountVAT' ) . '</td><td colspan="3" class="nowrap amountcard">' . price ( $object -> total_tva , 1 , '' , 1 , - 1 , - 1 , $conf -> currency ) . '</td></tr>' ;
2016-09-21 01:25:34 +02:00
print '</tr>' ;
2016-10-29 07:45:24 +02:00
2016-09-21 01:25:34 +02:00
// Amount Local Taxes
if (( $mysoc -> localtax1_assuj == " 1 " && $mysoc -> useLocalTax ( 1 )) || $object -> total_localtax1 != 0 ) // Localtax1
{
2017-10-16 08:47:05 +02:00
print '<tr><td>' . $langs -> transcountry ( " AmountLT1 " , $mysoc -> country_code ) . '</td>' ;
print '<td class="nowrap amountcard">' . price ( $object -> total_localtax1 , 1 , '' , 1 , - 1 , - 1 , $conf -> currency ) . '</td></tr>' ;
2016-09-21 01:25:34 +02:00
}
if (( $mysoc -> localtax2_assuj == " 1 " && $mysoc -> useLocalTax ( 2 )) || $object -> total_localtax2 != 0 ) // Localtax2
{
2017-10-16 08:47:05 +02:00
print '<tr><td>' . $langs -> transcountry ( " AmountLT2 " , $mysoc -> country_code ) . '</td>' ;
print '<td class=nowrap amountcard">' . price ( $object -> total_localtax2 , 1 , '' , 1 , - 1 , - 1 , $conf -> currency ) . '</td></tr>' ;
2016-09-21 01:25:34 +02:00
}
2016-10-29 07:45:24 +02:00
2016-09-21 01:25:34 +02:00
// Revenue stamp
if ( $selleruserevenustamp ) // Test company use revenue stamp
{
2017-10-16 08:47:05 +02:00
print '<tr><td>' ;
print '<table class="nobordernopadding" width="100%"><tr><td>' ;
print $langs -> trans ( 'RevenueStamp' );
print '</td>' ;
2018-11-14 14:59:36 +01:00
if ( $action != 'editrevenuestamp' && ! empty ( $object -> brouillon ) && $usercancreate )
2017-10-16 08:47:05 +02:00
{
print '<td align="right"><a href="' . $_SERVER [ " PHP_SELF " ] . '?action=editrevenuestamp&facid=' . $object -> id . '">' . img_edit ( $langs -> trans ( 'SetRevenuStamp' ), 1 ) . '</a></td>' ;
}
print '</tr></table>' ;
print '</td><td>' ;
if ( $action == 'editrevenuestamp' ) {
print '<form action="' . $_SERVER [ " PHP_SELF " ] . '?id=' . $object -> id . '" method="post">' ;
print '<input type="hidden" name="token" value="' . $_SESSION [ 'newtoken' ] . '">' ;
print '<input type="hidden" name="action" value="setrevenuestamp">' ;
2017-12-18 12:43:03 +01:00
print '<input type="hidden" name="revenuestamp" id="revenuestamp_val" value="' . price2num ( $object -> revenuestamp ) . '">' ;
print $formother -> select_revenue_stamp ( '' , 'revenuestamp_type' , $mysoc -> country_code );
print ' → <span id="revenuestamp_span"></span>' ;
2017-10-16 08:47:05 +02:00
print ' <input type="submit" class="button" value="' . $langs -> trans ( 'Modify' ) . '">' ;
print '</form>' ;
2017-12-18 12:43:03 +01:00
print " <script>
$ ( document ) . ready ( function (){
js_recalculate_revenuestamp ();
$ ( 'select[name=revenuestamp_type]' ) . on ( 'change' , function (){
js_recalculate_revenuestamp ();
});
});
function js_recalculate_revenuestamp (){
var valselected = $ ( 'select[name=revenuestamp_type]' ) . val ();
console . log ( 'Calculate revenue stamp from ' + valselected );
var revenue = 0 ;
if ( valselected . indexOf ( '%' ) == - 1 )
{
revenue = valselected ;
}
else
{
var revenue_type = parseFloat ( valselected );
2017-12-19 00:39:01 +01:00
var amount_net = " .round( $object->total_ht , 2). " ;
2017-12-18 12:43:03 +01:00
revenue = revenue_type * amount_net / 100 ;
revenue = revenue . toFixed ( 2 );
}
$ ( '#revenuestamp_val' ) . val ( revenue );
$ ( '#revenuestamp_span' ) . html ( revenue );
}
</ script > " ;
2017-10-16 08:47:05 +02:00
} else {
print price ( $object -> revenuestamp , 1 , '' , 1 , - 1 , - 1 , $conf -> currency );
}
print '</td></tr>' ;
2016-09-21 01:25:34 +02:00
}
2016-10-29 07:45:24 +02:00
2016-09-21 01:25:34 +02:00
// Total with tax
2017-04-12 11:30:33 +02:00
print '<tr><td>' . $langs -> trans ( 'AmountTTC' ) . '</td><td class="nowrap amountcard">' . price ( $object -> total_ttc , 1 , '' , 1 , - 1 , - 1 , $conf -> currency ) . '</td></tr>' ;
2016-10-29 07:45:24 +02:00
2016-09-21 01:25:34 +02:00
print '</table>' ;
2016-10-29 07:45:24 +02:00
2016-12-24 21:39:40 +01:00
2016-09-21 01:25:34 +02:00
$sign = 1 ;
if ( $object -> type == Facture :: TYPE_CREDIT_NOTE ) $sign = - 1 ;
2017-10-16 08:47:05 +02:00
$nbrows = 8 ;
$nbcols = 3 ;
if ( ! empty ( $conf -> projet -> enabled ))
$nbrows ++ ;
if ( ! empty ( $conf -> banque -> enabled )) {
$nbrows ++ ;
$nbcols ++ ;
}
if ( $mysoc -> localtax1_assuj == " 1 " || $object -> total_localtax1 != 0 )
$nbrows ++ ;
if ( $mysoc -> localtax2_assuj == " 1 " || $object -> total_localtax2 != 0 )
$nbrows ++ ;
if ( $selleruserevenustamp )
$nbrows ++ ;
if ( ! empty ( $conf -> multicurrency -> enabled ))
$nbrows += 5 ;
if ( ! empty ( $conf -> incoterm -> enabled ))
$nbrows += 1 ;
2018-05-16 15:55:42 +02:00
// List of previous situation invoices
if (( $object -> situation_cycle_ref > 0 ) && ! empty ( $conf -> global -> INVOICE_USE_SITUATION ))
2017-10-16 08:47:05 +02:00
{
2018-05-16 15:55:42 +02:00
print '<table class="noborder situationstable" width="100%">' ;
2018-05-23 08:16:24 +02:00
2018-05-16 15:55:42 +02:00
print '<tr class="liste_titre">' ;
print '<td>' . $langs -> trans ( 'ListOfSituationInvoices' ) . '</td>' ;
print '<td></td>' ;
print '<td align="center">' . $langs -> trans ( 'Situation' ) . '</td>' ;
if ( ! empty ( $conf -> banque -> enabled )) print '<td align="right"></td>' ;
print '<td align="right">' . $langs -> trans ( 'AmountHT' ) . '</td>' ;
print '<td align="right">' . $langs -> trans ( 'AmountTTC' ) . '</td>' ;
print '<td width="18"> </td>' ;
print '</tr>' ;
2018-05-23 08:16:24 +02:00
2018-05-16 15:55:42 +02:00
$total_prev_ht = $total_prev_ttc = 0 ;
$total_global_ht = $total_global_ttc = 0 ;
2018-05-23 08:16:24 +02:00
2018-05-16 15:55:42 +02:00
if ( count ( $object -> tab_previous_situation_invoice ) > 0 ) {
// List of previous invoices
2018-05-23 08:16:24 +02:00
2018-05-16 15:55:42 +02:00
$current_situation_counter = array ();
foreach ( $object -> tab_previous_situation_invoice as $prev_invoice ) {
$totalpaye = $prev_invoice -> getSommePaiement ();
$total_prev_ht += $prev_invoice -> total_ht ;
$total_prev_ttc += $prev_invoice -> total_ttc ;
$current_situation_counter [] = (( $prev_invoice -> type == Facture :: TYPE_CREDIT_NOTE ) ? - 1 : 1 ) * $prev_invoice -> situation_counter ;
print '<tr class="oddeven">' ;
print '<td>' . $prev_invoice -> getNomUrl ( 1 ) . '</td>' ;
print '<td></td>' ;
print '<td align="center" >' . (( $prev_invoice -> type == Facture :: TYPE_CREDIT_NOTE ) ? $langs -> trans ( 'situationInvoiceShortcode_AS' ) : $langs -> trans ( 'situationInvoiceShortcode_S' )) . $prev_invoice -> situation_counter . '</td>' ;
if ( ! empty ( $conf -> banque -> enabled )) print '<td align="right"></td>' ;
print '<td align="right">' . price ( $prev_invoice -> total_ht ) . '</td>' ;
print '<td align="right">' . price ( $prev_invoice -> total_ttc ) . '</td>' ;
print '<td align="right">' . $prev_invoice -> getLibStatut ( 3 , $totalpaye ) . '</td>' ;
print '</tr>' ;
}
}
2017-10-16 08:47:05 +02:00
2018-05-16 15:55:42 +02:00
$total_global_ht += $total_prev_ht ;
$total_global_ttc += $total_prev_ttc ;
$total_global_ht += $object -> total_ht ;
$total_global_ttc += $object -> total_ttc ;
$current_situation_counter [] = (( $object -> type == Facture :: TYPE_CREDIT_NOTE ) ? - 1 : 1 ) * $object -> situation_counter ;
print '<tr class="oddeven">' ;
print '<td>' . $object -> getNomUrl ( 1 ) . '</td>' ;
print '<td></td>' ;
print '<td align="center">' . (( $object -> type == Facture :: TYPE_CREDIT_NOTE ) ? $langs -> trans ( 'situationInvoiceShortcode_AS' ) : $langs -> trans ( 'situationInvoiceShortcode_S' )) . $object -> situation_counter . '</td>' ;
if ( ! empty ( $conf -> banque -> enabled )) print '<td align="right"></td>' ;
print '<td align="right">' . price ( $object -> total_ht ) . '</td>' ;
print '<td align="right">' . price ( $object -> total_ttc ) . '</td>' ;
print '<td align="right">' . $object -> getLibStatut ( 3 , $object -> getSommePaiement ()) . '</td>' ;
print '</tr>' ;
2018-05-23 08:16:24 +02:00
2018-05-16 15:55:42 +02:00
print '<tr class="oddeven">' ;
print '<td colspan="2" align="left"><b>' . $langs -> trans ( 'CurrentSituationTotal' ) . '</b></td>' ;
print '<td>' ;
$i = 0 ;
foreach ( $current_situation_counter as $sit )
{
$curSign = $sit > 0 ? '+' : '-' ;
$curType = $sit > 0 ? $langs -> trans ( 'situationInvoiceShortcode_S' ) : $langs -> trans ( 'situationInvoiceShortcode_AS' );
if ( $i > 0 ) print ' ' . $curSign . ' ' ;
print $curType . abs ( $sit );
$i ++ ;
}
print '</td>' ;
if ( ! empty ( $conf -> banque -> enabled )) print '<td></td>' ;
print '<td align="right"><b>' . price ( $total_global_ht ) . '</b></td>' ;
print '<td align="right"><b>' . price ( $total_global_ttc ) . '</b></td>' ;
print '<td width="18"> </td>' ;
print '</tr>' ;
2018-05-23 08:16:24 +02:00
2018-05-16 15:55:42 +02:00
if ( count ( $object -> tab_next_situation_invoice ) > 0 ) {
// List of next invoices
/* print '<tr class="liste_titre">' ;
print '<td>' . $langs -> trans ( 'ListOfNextSituationInvoices' ) . '</td>' ;
print '<td></td>' ;
print '<td></td>' ;
if ( ! empty ( $conf -> banque -> enabled )) print '<td align="right"></td>' ;
print '<td align="right">' . $langs -> trans ( 'AmountHT' ) . '</td>' ;
print '<td align="right">' . $langs -> trans ( 'AmountTTC' ) . '</td>' ;
print '<td width="18"> </td>' ;
print '</tr>' ; */
2018-05-23 08:16:24 +02:00
2018-05-16 15:55:42 +02:00
$total_next_ht = $total_next_ttc = 0 ;
2018-05-23 08:16:24 +02:00
2018-05-16 15:55:42 +02:00
foreach ( $object -> tab_next_situation_invoice as $next_invoice ) {
$totalpaye = $next_invoice -> getSommePaiement ();
$total_next_ht += $next_invoice -> total_ht ;
$total_next_ttc += $next_invoice -> total_ttc ;
2018-05-23 08:16:24 +02:00
2018-05-16 15:55:42 +02:00
print '<tr class="oddeven">' ;
print '<td>' . $next_invoice -> getNomUrl ( 1 ) . '</td>' ;
print '<td></td>' ;
print '<td align="center">' . (( $next_invoice -> type == Facture :: TYPE_CREDIT_NOTE ) ? $langs -> trans ( 'situationInvoiceShortcode_AS' ) : $langs -> trans ( 'situationInvoiceShortcode_S' )) . $next_invoice -> situation_counter . '</td>' ;
if ( ! empty ( $conf -> banque -> enabled )) print '<td align="right"></td>' ;
print '<td align="right">' . price ( $next_invoice -> total_ht ) . '</td>' ;
print '<td align="right">' . price ( $next_invoice -> total_ttc ) . '</td>' ;
print '<td align="right">' . $next_invoice -> getLibStatut ( 3 , $totalpaye ) . '</td>' ;
print '</tr>' ;
}
2017-10-16 08:47:05 +02:00
2018-05-16 15:55:42 +02:00
$total_global_ht += $total_next_ht ;
$total_global_ttc += $total_next_ttc ;
2017-10-16 08:47:05 +02:00
2018-05-16 15:55:42 +02:00
print '<tr class="oddeven">' ;
print '<td colspan="3" align="right"></td>' ;
if ( ! empty ( $conf -> banque -> enabled )) print '<td align="right"></td>' ;
print '<td align="right"><b>' . price ( $total_global_ht ) . '</b></td>' ;
print '<td align="right"><b>' . price ( $total_global_ttc ) . '</b></td>' ;
print '<td width="18"> </td>' ;
print '</tr>' ;
}
2017-10-16 08:47:05 +02:00
2018-05-16 15:55:42 +02:00
print '</table>' ;
2017-10-16 08:47:05 +02:00
}
// List of payments already done
2017-12-03 11:59:16 +01:00
2017-11-24 14:23:25 +01:00
print '<div class="div-table-responsive-no-min">' ;
2017-10-16 08:47:05 +02:00
print '<table class="noborder paymenttable" width="100%">' ;
print '<tr class="liste_titre">' ;
print '<td class="liste_titre">' . ( $object -> type == Facture :: TYPE_CREDIT_NOTE ? $langs -> trans ( " PaymentsBack " ) : $langs -> trans ( 'Payments' )) . '</td>' ;
print '<td class="liste_titre">' . $langs -> trans ( 'Date' ) . '</td>' ;
print '<td class="liste_titre">' . $langs -> trans ( 'Type' ) . '</td>' ;
if ( ! empty ( $conf -> banque -> enabled )) {
print '<td class="liste_titre" align="right">' . $langs -> trans ( 'BankAccount' ) . '</td>' ;
}
print '<td class="liste_titre" align="right">' . $langs -> trans ( 'Amount' ) . '</td>' ;
print '<td class="liste_titre" width="18"> </td>' ;
print '</tr>' ;
// Payments already done (from payment on this invoice)
$sql = 'SELECT p.datep as dp, p.ref, p.num_paiement, p.rowid, p.fk_bank,' ;
$sql .= ' c.code as payment_code, c.libelle as payment_label,' ;
$sql .= ' pf.amount,' ;
$sql .= ' ba.rowid as baid, ba.ref as baref, ba.label, ba.number as banumber, ba.account_number, ba.fk_accountancy_journal' ;
2017-11-23 15:06:16 +01:00
$sql .= ' FROM ' . MAIN_DB_PREFIX . 'paiement_facture as pf, ' . MAIN_DB_PREFIX . 'paiement as p' ;
$sql .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'c_paiement as c ON p.fk_paiement = c.id' ;
2017-10-16 08:47:05 +02:00
$sql .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'bank as b ON p.fk_bank = b.rowid' ;
$sql .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'bank_account as ba ON b.fk_account = ba.rowid' ;
2017-11-23 15:06:16 +01:00
$sql .= ' WHERE pf.fk_facture = ' . $object -> id . ' AND pf.fk_paiement = p.rowid' ;
2018-11-15 17:27:49 +01:00
$sql .= ' AND p.entity IN (' . getEntity ( 'invoice' ) . ')' ;
2017-10-16 08:47:05 +02:00
$sql .= ' ORDER BY p.datep, p.tms' ;
$result = $db -> query ( $sql );
if ( $result ) {
$num = $db -> num_rows ( $result );
$i = 0 ;
// if ($object->type != 2)
// {
if ( $num > 0 ) {
while ( $i < $num ) {
$objp = $db -> fetch_object ( $result );
$paymentstatic -> id = $objp -> rowid ;
$paymentstatic -> datepaye = $db -> jdate ( $objp -> dp );
$paymentstatic -> ref = $objp -> ref ;
$paymentstatic -> num_paiement = $objp -> num_paiement ;
$paymentstatic -> payment_code = $objp -> payment_code ;
print '<tr class="oddeven"><td>' ;
print $paymentstatic -> getNomUrl ( 1 );
print '</td>' ;
print '<td>' . dol_print_date ( $db -> jdate ( $objp -> dp ), 'day' ) . '</td>' ;
$label = ( $langs -> trans ( " PaymentType " . $objp -> payment_code ) != ( " PaymentType " . $objp -> payment_code )) ? $langs -> trans ( " PaymentType " . $objp -> payment_code ) : $objp -> payment_label ;
print '<td>' . $label . ' ' . $objp -> num_paiement . '</td>' ;
if ( ! empty ( $conf -> banque -> enabled ))
{
$bankaccountstatic -> id = $objp -> baid ;
$bankaccountstatic -> ref = $objp -> baref ;
$bankaccountstatic -> label = $objp -> baref ;
2017-05-14 21:20:35 +02:00
$bankaccountstatic -> number = $objp -> banumber ;
2017-05-15 05:11:00 +02:00
if ( ! empty ( $conf -> accounting -> enabled )) {
$bankaccountstatic -> account_number = $objp -> account_number ;
$accountingjournal = new AccountingJournal ( $db );
$accountingjournal -> fetch ( $objp -> fk_accountancy_journal );
$bankaccountstatic -> accountancy_journal = $accountingjournal -> getNomUrl ( 0 , 1 , 1 , '' , 1 );
}
2017-05-14 21:20:35 +02:00
print '<td align="right">' ;
2017-10-16 08:47:05 +02:00
if ( $bankaccountstatic -> id )
print $bankaccountstatic -> getNomUrl ( 1 , 'transactions' );
print '</td>' ;
}
print '<td align="right">' . price ( $sign * $objp -> amount ) . '</td>' ;
2017-12-03 11:59:16 +01:00
print '<td align="center">' ;
if ( $object -> statut == Facture :: STATUS_VALIDATED && $object -> paye == 0 && $user -> societe_id == 0 )
{
print '<a href="' . $_SERVER [ " PHP_SELF " ] . '?id=' . $object -> id . '&action=deletepaiement&paiement_id=' . $objp -> rowid . '">' ;
print img_delete ();
print '</a>' ;
}
print '</td>' ;
2017-10-16 08:47:05 +02:00
print '</tr>' ;
$i ++ ;
}
}
/* else {
2017-04-12 12:13:38 +02:00
print '<tr class="oddeven"><td colspan="' . $nbcols . '" class="opacitymedium">' . $langs -> trans ( " None " ) . '</td><td></td><td></td></tr>' ;
} */
2017-10-16 08:47:05 +02:00
// }
$db -> free ( $result );
} else {
dol_print_error ( $db );
}
if ( $object -> type != Facture :: TYPE_CREDIT_NOTE ) {
// Total already paid
print '<tr><td colspan="' . $nbcols . '" align="right">' ;
if ( $object -> type != Facture :: TYPE_DEPOSIT )
print $langs -> trans ( 'AlreadyPaidNoCreditNotesNoDeposits' );
else
print $langs -> trans ( 'AlreadyPaid' );
print ' :</td><td align="right"' . (( $totalpaye > 0 ) ? ' class="amountalreadypaid"' : '' ) . '>' . price ( $totalpaye ) . '</td><td> </td></tr>' ;
$resteapayeraffiche = $resteapayer ;
$cssforamountpaymentcomplete = 'amountpaymentcomplete' ;
// Loop on each credit note or deposit amount applied
$creditnoteamount = 0 ;
$depositamount = 0 ;
$sql = " SELECT re.rowid, re.amount_ht, re.amount_tva, re.amount_ttc, " ;
$sql .= " re.description, re.fk_facture_source " ;
$sql .= " FROM " . MAIN_DB_PREFIX . " societe_remise_except as re " ;
$sql .= " WHERE fk_facture = " . $object -> id ;
$resql = $db -> query ( $sql );
if ( $resql ) {
$num = $db -> num_rows ( $resql );
$i = 0 ;
$invoice = new Facture ( $db );
while ( $i < $num ) {
$obj = $db -> fetch_object ( $resql );
$invoice -> fetch ( $obj -> fk_facture_source );
print '<tr><td colspan="' . $nbcols . '" align="right">' ;
if ( $invoice -> type == Facture :: TYPE_CREDIT_NOTE )
print $langs -> trans ( " CreditNote " ) . ' ' ;
if ( $invoice -> type == Facture :: TYPE_DEPOSIT )
print $langs -> trans ( " Deposit " ) . ' ' ;
print $invoice -> getNomUrl ( 0 );
print ' :</td>' ;
print '<td align="right">' . price ( $obj -> amount_ttc ) . '</td>' ;
print '<td align="right">' ;
print '<a href="' . $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id . '&action=unlinkdiscount&discountid=' . $obj -> rowid . '">' . img_delete () . '</a>' ;
print '</td></tr>' ;
$i ++ ;
if ( $invoice -> type == Facture :: TYPE_CREDIT_NOTE )
$creditnoteamount += $obj -> amount_ttc ;
if ( $invoice -> type == Facture :: TYPE_DEPOSIT )
$depositamount += $obj -> amount_ttc ;
}
} else {
dol_print_error ( $db );
}
// Paye partiellement 'escompte'
if (( $object -> statut == Facture :: STATUS_CLOSED || $object -> statut == Facture :: STATUS_ABANDONED ) && $object -> close_code == 'discount_vat' ) {
print '<tr><td colspan="' . $nbcols . '" align="right" class="nowrap">' ;
print $form -> textwithpicto ( $langs -> trans ( " Discount " ) . ':' , $langs -> trans ( " HelpEscompte " ), - 1 );
2018-03-22 09:41:30 +01:00
print '</td><td align="right">' . price ( price2num ( $object -> total_ttc - $creditnoteamount - $depositamount - $totalpaye , 'MT' )) . '</td><td> </td></tr>' ;
2017-10-16 08:47:05 +02:00
$resteapayeraffiche = 0 ;
2018-06-23 14:39:24 +02:00
$cssforamountpaymentcomplete = 'amountpaymentneutral' ;
2017-10-16 08:47:05 +02:00
}
// Paye partiellement ou Abandon 'badcustomer'
if (( $object -> statut == Facture :: STATUS_CLOSED || $object -> statut == Facture :: STATUS_ABANDONED ) && $object -> close_code == 'badcustomer' ) {
print '<tr><td colspan="' . $nbcols . '" align="right" class="nowrap">' ;
print $form -> textwithpicto ( $langs -> trans ( " Abandoned " ) . ':' , $langs -> trans ( " HelpAbandonBadCustomer " ), - 1 );
2018-03-22 09:41:30 +01:00
print '</td><td align="right">' . price ( price2num ( $object -> total_ttc - $creditnoteamount - $depositamount - $totalpaye , 'MT' )) . '</td><td> </td></tr>' ;
2017-10-16 08:47:05 +02:00
// $resteapayeraffiche=0;
2018-06-23 14:39:24 +02:00
$cssforamountpaymentcomplete = 'amountpaymentneutral' ;
2017-10-16 08:47:05 +02:00
}
// Paye partiellement ou Abandon 'product_returned'
if (( $object -> statut == Facture :: STATUS_CLOSED || $object -> statut == Facture :: STATUS_ABANDONED ) && $object -> close_code == 'product_returned' ) {
print '<tr><td colspan="' . $nbcols . '" align="right" class="nowrap">' ;
print $form -> textwithpicto ( $langs -> trans ( " ProductReturned " ) . ':' , $langs -> trans ( " HelpAbandonProductReturned " ), - 1 );
2018-03-22 09:41:30 +01:00
print '</td><td align="right">' . price ( price2num ( $object -> total_ttc - $creditnoteamount - $depositamount - $totalpaye , 'MT' )) . '</td><td> </td></tr>' ;
2017-10-16 08:47:05 +02:00
$resteapayeraffiche = 0 ;
2018-06-23 14:39:24 +02:00
$cssforamountpaymentcomplete = 'amountpaymentneutral' ;
2017-10-16 08:47:05 +02:00
}
// Paye partiellement ou Abandon 'abandon'
if (( $object -> statut == Facture :: STATUS_CLOSED || $object -> statut == Facture :: STATUS_ABANDONED ) && $object -> close_code == 'abandon' ) {
print '<tr><td colspan="' . $nbcols . '" align="right" class="nowrap">' ;
$text = $langs -> trans ( " HelpAbandonOther " );
if ( $object -> close_note )
$text .= '<br><br><b>' . $langs -> trans ( " Reason " ) . '</b>:' . $object -> close_note ;
print $form -> textwithpicto ( $langs -> trans ( " Abandoned " ) . ':' , $text , - 1 );
2018-03-22 09:41:30 +01:00
print '</td><td align="right">' . price ( price2num ( $object -> total_ttc - $creditnoteamount - $depositamount - $totalpaye , 'MT' )) . '</td><td> </td></tr>' ;
2017-10-16 08:47:05 +02:00
$resteapayeraffiche = 0 ;
2018-06-23 14:39:24 +02:00
$cssforamountpaymentcomplete = 'amountpaymentneutral' ;
2017-10-16 08:47:05 +02:00
}
// Billed
print '<tr><td colspan="' . $nbcols . '" align="right">' . $langs -> trans ( " Billed " ) . ' :</td><td align="right">' . price ( $object -> total_ttc ) . '</td><td> </td></tr>' ;
// Remainder to pay
print '<tr><td colspan="' . $nbcols . '" align="right">' ;
if ( $resteapayeraffiche >= 0 )
print $langs -> trans ( 'RemainderToPay' );
else
print $langs -> trans ( 'ExcessReceived' );
print ' :</td>' ;
print '<td align="right"' . ( $resteapayeraffiche ? ' class="amountremaintopay"' : ( ' class="' . $cssforamountpaymentcomplete . '"' )) . '>' . price ( $resteapayeraffiche ) . '</td>' ;
print '<td class="nowrap"> </td></tr>' ;
}
else // Credit note
{
2018-08-13 14:04:10 +02:00
$cssforamountpaymentcomplete = 'amountpaymentneutral' ;
2017-10-16 08:47:05 +02:00
// Total already paid back
print '<tr><td colspan="' . $nbcols . '" align="right">' ;
print $langs -> trans ( 'AlreadyPaidBack' );
print ' :</td><td align="right">' . price ( $sign * $totalpaye ) . '</td><td> </td></tr>' ;
// Billed
print '<tr><td colspan="' . $nbcols . '" align="right">' . $langs -> trans ( " Billed " ) . ' :</td><td align="right">' . price ( $sign * $object -> total_ttc ) . '</td><td> </td></tr>' ;
// Remainder to pay back
print '<tr><td colspan="' . $nbcols . '" align="right">' ;
if ( $resteapayeraffiche <= 0 )
print $langs -> trans ( 'RemainderToPayBack' );
else
2018-08-13 14:04:10 +02:00
print $langs -> trans ( 'ExcessPaid' );
2017-10-16 08:47:05 +02:00
print ' :</td>' ;
print '<td align="right"' . ( $resteapayeraffiche ? ' class="amountremaintopayback"' : ( ' class="' . $cssforamountpaymentcomplete . '"' )) . '>' . price ( $sign * $resteapayeraffiche ) . '</td>' ;
print '<td class="nowrap"> </td></tr>' ;
// Sold credit note
// print '<tr><td colspan="'.$nbcols.'" align="right">'.$langs->trans('TotalTTC').' :</td>';
// print '<td align="right" style="border: 1px solid;" bgcolor="#f0f0f0"><b>'.price($sign *
// $object->total_ttc).'</b></td><td> </td></tr>';
}
print '</table>' ;
2017-11-24 14:23:25 +01:00
print '</div>' ;
2016-10-29 07:45:24 +02:00
2016-09-21 01:25:34 +02:00
// Margin Infos
if ( ! empty ( $conf -> margin -> enabled )) {
2017-10-16 08:47:05 +02:00
$formmargin -> displayMarginInfos ( $object );
2016-09-21 01:25:34 +02:00
}
2014-03-01 19:45:13 +01:00
2016-09-21 01:25:34 +02:00
print '</div>' ;
print '</div>' ;
print '</div>' ;
2016-10-29 07:45:24 +02:00
2016-09-21 01:25:34 +02:00
print '<div class="clearboth"></div><br>' ;
2016-10-29 07:45:24 +02:00
2014-02-23 20:10:05 +01:00
if ( ! empty ( $conf -> global -> MAIN_DISABLE_CONTACTS_TAB )) {
2013-11-17 23:25:25 +01:00
$blocname = 'contacts' ;
$title = $langs -> trans ( 'ContactsAddresses' );
2014-02-23 20:10:05 +01:00
include DOL_DOCUMENT_ROOT . '/core/tpl/bloc_showhide.tpl.php' ;
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
if ( ! empty ( $conf -> global -> MAIN_DISABLE_NOTES_TAB )) {
2013-11-17 23:25:25 +01:00
$blocname = 'notes' ;
$title = $langs -> trans ( 'Notes' );
2014-02-23 20:10:05 +01:00
include DOL_DOCUMENT_ROOT . '/core/tpl/bloc_showhide.tpl.php' ;
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Lines
$result = $object -> getLinesArray ();
2014-03-01 19:45:13 +01:00
2014-11-14 16:43:49 +01:00
// Show global modifiers
2016-10-04 11:30:51 +02:00
if ( ! empty ( $conf -> global -> INVOICE_USE_SITUATION ))
2015-01-18 18:44:22 +01:00
{
2015-06-03 11:55:39 +02:00
if ( $object -> situation_cycle_ref && $object -> statut == 0 ) {
2017-05-10 16:10:14 +02:00
print '<div class="div-table-responsive">' ;
2017-06-07 16:44:04 +02:00
2017-05-15 15:10:15 +02:00
print '<form name="updatealllines" id="updatealllines" action="' . $_SERVER [ 'PHP_SELF' ] . '?id=' . $object -> id . '#updatealllines" method="POST">' ;
2015-06-03 11:55:39 +02:00
print '<input type="hidden" name="token" value="' . $_SESSION [ 'newtoken' ] . '" />' ;
print '<input type="hidden" name="action" value="updatealllines" />' ;
print '<input type="hidden" name="id" value="' . $object -> id . '" />' ;
2017-06-07 16:44:04 +02:00
2017-05-15 15:05:42 +02:00
print '<table id="tablelines_all_progress" class="noborder noshadow" width="100%">' ;
2017-06-07 16:44:04 +02:00
2017-05-11 09:04:14 +02:00
print '<tr class="liste_titre nodrag nodrop">' ;
2015-06-03 11:55:39 +02:00
2018-09-25 17:26:57 +02:00
// Adds a line numbering column
2015-06-03 11:55:39 +02:00
if ( ! empty ( $conf -> global -> MAIN_VIEW_LINE_NUMBER )) {
print '<td align="center" width="5"> </td>' ;
}
print '<td>' . $langs -> trans ( 'ModifyAllLines' ) . '</td>' ;
print '<td align="right" width="50"> </td>' ;
print '<td align="right" width="80"> </td>' ;
if ( $inputalsopricewithtax ) print '<td align="right" width="80"> </td>' ;
print '<td align="right" width="50"> </td>' ;
print '<td align="right" width="50"> </td>' ;
print '<td align="right" width="50">' . $langs -> trans ( 'Progress' ) . '</td>' ;
if ( ! empty ( $conf -> margin -> enabled ) && empty ( $user -> societe_id ))
{
print '<td align="right" class="margininfos" width="80"> </td>' ;
2018-11-14 14:59:36 +01:00
if (( ! empty ( $conf -> global -> DISPLAY_MARGIN_RATES ) || ! empty ( $conf -> global -> DISPLAY_MARK_RATES )) && $usercanreadallmargin ) {
2015-06-03 11:55:39 +02:00
print '<td align="right" class="margininfos" width="50"> </td>' ;
}
}
print '<td align="right" width="50"> </td>' ;
print '<td> </td>' ;
print '<td width="10"> </td>' ;
print '<td width="10"> </td>' ;
print " </tr> \n " ;
2018-09-25 17:26:57 +02:00
// Adds a line numbering column
2015-06-03 11:55:39 +02:00
if ( ! empty ( $conf -> global -> MAIN_VIEW_LINE_NUMBER )) {
print '<td align="center" width="5"> </td>' ;
}
print '<tr width="100%" class="nodrag nodrop">' ;
print '<td> </td>' ;
print '<td width="50"> </td>' ;
print '<td width="80"> </td>' ;
print '<td width="50"> </td>' ;
print '<td width="50"> </td>' ;
print '<td align="right" class="nowrap"><input type="text" size="1" value="" name="all_progress">%</td>' ;
print '<td colspan="4" align="right"><input class="button" type="submit" name="all_percent" value="Modifier" /></td>' ;
print '</tr>' ;
2017-06-07 16:44:04 +02:00
2017-05-10 16:10:14 +02:00
print '</table>' ;
2017-06-07 16:44:04 +02:00
2015-06-03 11:55:39 +02:00
print '</form>' ;
2017-06-07 16:44:04 +02:00
2017-05-10 16:10:14 +02:00
print '</div>' ;
2015-06-03 11:55:39 +02:00
}
2015-01-18 18:44:22 +01:00
}
2015-01-25 21:32:40 +01:00
2017-10-19 14:10:58 +02:00
print ' <form name="addproduct" id="addproduct" action="' . $_SERVER [ " PHP_SELF " ] . '?id=' . $object -> id . (( $action != 'editline' ) ? '#addline' : '#line_' . GETPOST ( 'lineid' )) . ' " method= " POST " >
2017-05-10 16:10:14 +02:00
< input type = " hidden " name = " token " value = " ' . $_SESSION ['newtoken'] . ' " >
2018-09-28 16:15:17 +02:00
< input type = " hidden " name = " action " value = " ' . (( $action != 'editline') ? 'addline' : 'updateline') . ' " >
2017-05-10 16:10:14 +02:00
< input type = " hidden " name = " mode " value = " " >
< input type = " hidden " name = " id " value = " ' . $object->id . ' " >
' ;
2017-06-07 16:44:04 +02:00
2017-05-10 16:10:14 +02:00
if ( ! empty ( $conf -> use_javascript_ajax ) && $object -> statut == 0 ) {
2017-10-16 08:47:05 +02:00
include DOL_DOCUMENT_ROOT . '/core/tpl/ajaxrow.tpl.php' ;
2017-05-10 16:10:14 +02:00
}
2017-06-07 16:44:04 +02:00
2017-10-13 12:14:57 +02:00
print '<div class="div-table-responsive-no-min">' ;
2017-05-10 16:10:14 +02:00
print '<table id="tablelines" class="noborder noshadow" width="100%">' ;
2017-06-07 16:44:04 +02:00
2013-11-17 23:25:25 +01:00
// Show object lines
if ( ! empty ( $object -> lines ))
2014-02-23 20:10:05 +01:00
$ret = $object -> printObjectLines ( $action , $mysoc , $soc , $lineid , 1 );
2014-03-01 19:45:13 +01:00
2014-05-05 14:30:08 +02:00
// Form to add new line
2018-11-14 14:59:36 +01:00
if ( $object -> statut == 0 && $usercancreate && $action != 'valid' && $action != 'editline' && ( $object -> is_first () || ! $object -> situation_cycle_ref ))
2014-05-05 14:30:08 +02:00
{
2018-02-21 17:06:40 +01:00
if ( $action != 'editline' && $action != 'selectlines' )
2014-04-28 11:55:08 +02:00
{
2013-11-17 23:25:25 +01:00
// Add free products/services
2014-05-05 14:30:08 +02:00
$object -> formAddObjectLine ( 1 , $mysoc , $soc );
2014-03-01 19:45:13 +01:00
2014-05-05 14:30:08 +02:00
$parameters = array ();
$reshook = $hookmanager -> executeHooks ( 'formAddObjectLine' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
2013-11-17 23:25:25 +01:00
}
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
print " </table> \n " ;
2017-10-16 08:47:05 +02:00
print " </div> " ;
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
print " </form> \n " ;
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
dol_fiche_end ();
2014-03-01 19:45:13 +01:00
2014-04-23 13:14:55 +02:00
// Actions buttons
if ( $action != 'prerelance' && $action != 'presend' && $action != 'valid' && $action != 'editline' )
{
2014-01-24 11:15:25 +01:00
print '<div class="tabsAction">' ;
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
$parameters = array ();
2016-10-29 07:45:24 +02:00
$reshook = $hookmanager -> executeHooks ( 'addMoreActionsButtons' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
2014-02-23 20:10:05 +01:00
if ( empty ( $reshook )) {
2013-11-17 23:25:25 +01:00
// Editer une facture deja validee, sans paiement effectue et pas exporte en compta
2017-09-27 16:29:33 +02:00
if ( $object -> statut == Facture :: STATUS_VALIDATED )
2015-08-31 12:34:59 +02:00
{
2013-11-17 23:25:25 +01:00
// On verifie si les lignes de factures ont ete exportees en compta et/ou ventilees
$ventilExportCompta = $object -> getVentilExportCompta ();
2014-03-01 19:45:13 +01:00
2017-09-27 16:29:33 +02:00
if ( $ventilExportCompta == 0 )
2015-08-31 12:34:59 +02:00
{
2017-09-27 16:29:33 +02:00
if ( ! empty ( $conf -> global -> INVOICE_CAN_ALWAYS_BE_EDITED ) || ( $resteapayer == $object -> total_ttc && empty ( $object -> paye )))
2015-08-31 12:34:59 +02:00
{
2017-09-27 16:29:33 +02:00
if ( ! $objectidnext && $object -> is_last_in_cycle ())
2015-01-25 21:32:40 +01:00
{
2018-11-14 14:59:36 +01:00
if ( $usercanunvalidate )
2017-09-27 16:29:33 +02:00
{
2018-03-31 23:39:08 +02:00
print '<div class="inline-block divButAction"><a class="butAction' . ( $conf -> use_javascript_ajax ? ' reposition' : '' ) . '" href="' . $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id . '&action=modif">' . $langs -> trans ( 'Modify' ) . '</a></div>' ;
2017-09-27 16:29:33 +02:00
} else {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><span class="butActionRefused classfortooltip" title="' . $langs -> trans ( " NotEnoughPermissions " ) . '">' . $langs -> trans ( 'Modify' ) . '</span></div>' ;
2017-09-27 16:29:33 +02:00
}
} else if ( ! $object -> is_last_in_cycle ()) {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><span class="butActionRefused classfortooltip" title="' . $langs -> trans ( " NotLastInCycle " ) . '">' . $langs -> trans ( 'Modify' ) . '</span></div>' ;
2014-02-23 20:10:05 +01:00
} else {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><span class="butActionRefused classfortooltip" title="' . $langs -> trans ( " DisabledBecauseReplacedInvoice " ) . '">' . $langs -> trans ( 'Modify' ) . '</span></div>' ;
2013-04-20 00:10:20 +02:00
}
2013-04-20 17:10:03 +02:00
}
2013-11-17 23:25:25 +01:00
}
2017-09-27 16:29:33 +02:00
else
{
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><span class="butActionRefused classfortooltip" title="' . $langs -> trans ( " DisabledBecauseDispatchedInAccounting " ) . '">' . $langs -> trans ( 'Modify' ) . '</span></div>' ;
2017-09-27 16:29:33 +02:00
}
2013-11-17 23:25:25 +01:00
}
2017-06-07 16:44:04 +02:00
2016-11-28 17:38:20 +01:00
$discount = new DiscountAbsolute ( $db );
$result = $discount -> fetch ( 0 , $object -> id );
2017-06-07 16:44:04 +02:00
2013-11-17 23:25:25 +01:00
// Reopen a standard paid invoice
2014-03-19 22:59:10 +01:00
if ((( $object -> type == Facture :: TYPE_STANDARD || $object -> type == Facture :: TYPE_REPLACEMENT )
|| ( $object -> type == Facture :: TYPE_CREDIT_NOTE && empty ( $discount -> id ))
|| ( $object -> type == Facture :: TYPE_DEPOSIT && empty ( $discount -> id )))
2016-07-05 18:36:10 +02:00
&& ( $object -> statut == 2 || $object -> statut == 3 || ( $object -> statut == 1 && $object -> paye == 1 )) // Condition ($object->statut == 1 && $object->paye == 1) should not happened but can be found due to corrupted data
2018-11-14 14:59:36 +01:00
&& (( empty ( $conf -> global -> MAIN_USE_ADVANCED_PERMS ) && $usercancreate ) || $usercanreopen )) // A paid invoice (partially or completely)
2013-11-17 23:25:25 +01:00
{
2014-02-23 20:10:05 +01:00
if ( ! $objectidnext && $object -> close_code != 'replaced' ) // Not replaced by another invoice
2013-11-17 23:25:25 +01:00
{
2018-03-31 23:39:08 +02:00
print '<div class="inline-block divButAction"><a class="butAction' . ( $conf -> use_javascript_ajax ? ' reposition' : '' ) . '" href="' . $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id . '&action=reopen">' . $langs -> trans ( 'ReOpen' ) . '</a></div>' ;
2014-02-23 20:10:05 +01:00
} else {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><span class="butActionRefused classfortooltip" title="' . $langs -> trans ( " DisabledBecauseReplacedInvoice " ) . '">' . $langs -> trans ( 'ReOpen' ) . '</span></div>' ;
2013-11-17 23:25:25 +01:00
}
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Validate
2017-09-27 16:29:33 +02:00
if ( $object -> statut == Facture :: STATUS_DRAFT && count ( $object -> lines ) > 0 && ((( $object -> type == Facture :: TYPE_STANDARD || $object -> type == Facture :: TYPE_REPLACEMENT || $object -> type == Facture :: TYPE_DEPOSIT || $object -> type == Facture :: TYPE_PROFORMA || $object -> type == Facture :: TYPE_SITUATION ) && ( ! empty ( $conf -> global -> FACTURE_ENABLE_NEGATIVE ) || $object -> total_ttc >= 0 )) || ( $object -> type == Facture :: TYPE_CREDIT_NOTE && $object -> total_ttc <= 0 ))) {
2018-11-14 14:59:36 +01:00
if ( $usercanvalidate )
2015-01-25 21:32:40 +01:00
{
2018-03-31 23:39:08 +02:00
print '<div class="inline-block divButAction"><a class="butAction' . ( $conf -> use_javascript_ajax ? ' reposition' : '' ) . '" href="' . $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id . '&action=valid">' . $langs -> trans ( 'Validate' ) . '</a></div>' ;
2013-11-17 23:25:25 +01:00
}
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Send by mail
2017-02-10 10:43:54 +01:00
if (( $object -> statut == Facture :: STATUS_VALIDATED || $object -> statut == Facture :: STATUS_CLOSED ) || ! empty ( $conf -> global -> FACTURE_SENDBYEMAIL_FOR_ALL_STATUS )) {
2014-02-23 20:10:05 +01:00
if ( $objectidnext ) {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><span class="butActionRefused classfortooltip" title="' . $langs -> trans ( " DisabledBecauseReplacedInvoice " ) . '">' . $langs -> trans ( 'SendMail' ) . '</span></div>' ;
2014-02-23 20:10:05 +01:00
} else {
2018-11-14 14:59:36 +01:00
if ( $usercansend ) {
2018-03-11 21:34:38 +01:00
print '<div class="inline-block divButAction"><a class="butAction" href="' . $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id . '&action=presend&mode=init#formmailbeforetitle">' . $langs -> trans ( 'SendMail' ) . '</a></div>' ;
2014-02-23 20:10:05 +01:00
} else
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#">' . $langs -> trans ( 'SendMail' ) . '</a></div>' ;
2013-11-17 23:25:25 +01:00
}
}
2014-03-01 19:45:13 +01:00
2017-02-10 10:43:54 +01:00
// Request a direct debit order
if ( $object -> statut > Facture :: STATUS_DRAFT && $object -> paye == 0 && $num == 0 )
2013-11-17 23:25:25 +01:00
{
2017-10-16 08:47:05 +02:00
if ( $resteapayer > 0 )
{
2018-11-14 14:59:36 +01:00
if ( $usercancreatewithdrarequest )
2017-10-16 08:47:05 +02:00
{
2018-01-04 14:35:02 +01:00
if ( ! $objectidnext && $object -> close_code != 'replaced' ) // Not replaced by another invoice
{
print '<a class="butAction" href="' . DOL_URL_ROOT . '/compta/facture/prelevement.php?facid=' . $object -> id . '" title="' . dol_escape_htmltag ( $langs -> trans ( " MakeWithdrawRequest " )) . '">' . $langs -> trans ( " MakeWithdrawRequest " ) . '</a>' ;
} else {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><span class="butActionRefused classfortooltip" title="' . $langs -> trans ( " DisabledBecauseReplacedInvoice " ) . '">' . $langs -> trans ( 'MakeWithdrawRequest' ) . '</span></div>' ;
2018-01-04 14:35:02 +01:00
}
2017-10-16 08:47:05 +02:00
}
else
{
2018-11-13 21:40:17 +01:00
//print '<a class="butActionRefused classfortooltip" href="#" title="'.dol_escape_htmltag($langs->trans("NotEnoughPermissions")).'">'.$langs->trans("MakeWithdrawRequest").'</a>';
2017-10-16 08:47:05 +02:00
}
}
else
{
2018-11-13 21:40:17 +01:00
//print '<a class="butActionRefused classfortooltip" href="#" title="'.dol_escape_htmltag($langs->trans("AmountMustBePositive")).'">'.$langs->trans("MakeWithdrawRequest").'</a>';
2017-10-16 08:47:05 +02:00
}
2013-11-17 23:25:25 +01:00
}
2017-06-07 16:44:04 +02:00
2013-11-17 23:25:25 +01:00
// Create payment
2018-11-14 14:59:36 +01:00
if ( $object -> type != Facture :: TYPE_CREDIT_NOTE && $object -> statut == 1 && $object -> paye == 0 && $usercanissuepayment ) {
2014-02-23 20:10:05 +01:00
if ( $objectidnext ) {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><span class="butActionRefused classfortooltip" title="' . $langs -> trans ( " DisabledBecauseReplacedInvoice " ) . '">' . $langs -> trans ( 'DoPayment' ) . '</span></div>' ;
2014-02-23 20:10:05 +01:00
} else {
2018-07-02 11:33:33 +02:00
//if ($resteapayer == 0) { // Sometimes we can receive more, so we accept to enter more and will offer a button to convert into discount (but it is not a credit note, just a prepayment done)
2018-11-13 21:40:17 +01:00
// print '<div class="inline-block divButAction"><span class="butActionRefused classfortooltip" title="' . $langs->trans("DisabledBecauseRemainderToPayIsZero") . '">' . $langs->trans('DoPayment') . '</span></div>';
2017-08-24 15:39:23 +02:00
//} else {
2017-03-28 13:22:11 +02:00
print '<div class="inline-block divButAction"><a class="butAction" href="' . DOL_URL_ROOT . '/compta/paiement.php?facid=' . $object -> id . '&action=create&accountid=' . $object -> fk_account . '">' . $langs -> trans ( 'DoPayment' ) . '</a></div>' ;
2017-08-24 15:39:23 +02:00
//}
2013-11-17 23:25:25 +01:00
}
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Reverse back money or convert to reduction
2016-11-24 15:48:04 +01:00
if ( $object -> type == Facture :: TYPE_CREDIT_NOTE || $object -> type == Facture :: TYPE_DEPOSIT || $object -> type == Facture :: TYPE_STANDARD ) {
2013-11-17 23:25:25 +01:00
// For credit note only
2018-11-14 14:59:36 +01:00
if ( $object -> type == Facture :: TYPE_CREDIT_NOTE && $object -> statut == 1 && $object -> paye == 0 && $usercanissuepayment )
2013-11-17 23:25:25 +01:00
{
2014-03-19 22:30:25 +01:00
if ( $resteapayer == 0 )
{
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><span class="butActionRefused classfortooltip" title="' . $langs -> trans ( " DisabledBecauseRemainderToPayIsZero " ) . '">' . $langs -> trans ( 'DoPaymentBack' ) . '</span></div>' ;
2014-03-19 22:30:25 +01:00
}
else
{
2017-03-28 13:22:11 +02:00
print '<div class="inline-block divButAction"><a class="butAction" href="' . DOL_URL_ROOT . '/compta/paiement.php?facid=' . $object -> id . '&action=create&accountid=' . $object -> fk_account . '">' . $langs -> trans ( 'DoPaymentBack' ) . '</a></div>' ;
2014-03-19 22:30:25 +01:00
}
2013-11-17 23:25:25 +01:00
}
2014-03-19 22:30:25 +01:00
2016-11-24 15:48:04 +01:00
// For standard invoice with excess received
2018-11-14 14:59:36 +01:00
if ( $object -> type == Facture :: TYPE_STANDARD && empty ( $object -> paye ) && ( $object -> total_ttc - $totalpaye - $totalcreditnotes - $totaldeposits ) < 0 && $usercancreate && empty ( $discount -> id ))
2016-11-24 15:48:04 +01:00
{
2018-03-31 23:39:08 +02:00
print '<div class="inline-block divButAction"><a class="butAction' . ( $conf -> use_javascript_ajax ? ' reposition' : '' ) . '" href="' . $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id . '&action=converttoreduc">' . $langs -> trans ( 'ConvertExcessReceivedToReduc' ) . '</a></div>' ;
2016-11-24 15:48:04 +01:00
}
2013-11-17 23:25:25 +01:00
// For credit note
2018-11-14 14:59:36 +01:00
if ( $object -> type == Facture :: TYPE_CREDIT_NOTE && $object -> statut == 1 && $object -> paye == 0 && $usercancreate && $object -> getSommePaiement () == 0 ) {
2018-03-31 23:39:08 +02:00
print '<div class="inline-block divButAction"><a class="butAction' . ( $conf -> use_javascript_ajax ? ' reposition' : '' ) . '" href="' . $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id . '&action=converttoreduc">' . $langs -> trans ( 'ConvertToReduc' ) . '</a></div>' ;
2013-11-17 23:25:25 +01:00
}
// For deposit invoice
2018-11-14 14:59:36 +01:00
if ( $object -> type == Facture :: TYPE_DEPOSIT && $usercancreate && $object -> statut > 0 && empty ( $discount -> id ))
2013-11-17 23:25:25 +01:00
{
2018-03-31 23:39:08 +02:00
print '<div class="inline-block divButAction"><a class="butAction' . ( $conf -> use_javascript_ajax ? ' reposition' : '' ) . '" href="' . $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id . '&action=converttoreduc">' . $langs -> trans ( 'ConvertToReduc' ) . '</a></div>' ;
2013-11-17 23:25:25 +01:00
}
}
2014-03-01 19:45:13 +01:00
2014-03-19 22:30:25 +01:00
// Classify paid
2018-11-14 14:59:36 +01:00
if ( $object -> statut == 1 && $object -> paye == 0 && $usercanissuepayment && (( $object -> type != Facture :: TYPE_CREDIT_NOTE && $object -> type != Facture :: TYPE_DEPOSIT && $resteapayer <= 0 ) || ( $object -> type == Facture :: TYPE_CREDIT_NOTE && $resteapayer >= 0 ))
|| ( $object -> type == Facture :: TYPE_DEPOSIT && $object -> paye == 0 && $object -> total_ttc > 0 && $resteapayer == 0 && $usercanissuepayment && empty ( $discount -> id ))
2014-03-19 22:30:25 +01:00
)
2013-11-17 23:25:25 +01:00
{
2018-03-31 23:39:08 +02:00
print '<div class="inline-block divButAction"><a class="butAction' . ( $conf -> use_javascript_ajax ? ' reposition' : '' ) . '" href="' . $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id . '&action=paid">' . $langs -> trans ( 'ClassifyPaid' ) . '</a></div>' ;
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Classify 'closed not completely paid' (possible si validee et pas encore classee payee)
2016-08-10 09:47:25 +02:00
2018-11-14 14:59:36 +01:00
if ( $object -> statut == 1 && $object -> paye == 0 && $resteapayer > 0 && $usercanissuepayment )
2013-11-17 23:25:25 +01:00
{
if ( $totalpaye > 0 || $totalcreditnotes > 0 )
{
// If one payment or one credit note was linked to this invoice
2018-03-31 23:39:08 +02:00
print '<div class="inline-block divButAction"><a class="butAction' . ( $conf -> use_javascript_ajax ? ' reposition' : '' ) . '" href="' . $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id . '&action=paid">' . $langs -> trans ( 'ClassifyPaidPartially' ) . '</a></div>' ;
2013-11-17 23:25:25 +01:00
}
else
{
2016-03-25 18:16:05 +01:00
if ( empty ( $conf -> global -> INVOICE_CAN_NEVER_BE_CANCELED ))
2016-03-24 11:38:05 +01:00
{
2016-08-10 09:47:25 +02:00
if ( $objectidnext )
2016-03-24 11:38:05 +01:00
{
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><span class="butActionRefused classfortooltip" title="' . $langs -> trans ( " DisabledBecauseReplacedInvoice " ) . '">' . $langs -> trans ( 'ClassifyCanceled' ) . '</span></div>' ;
2016-03-24 11:38:05 +01:00
}
2016-08-10 09:47:25 +02:00
else
2016-03-24 11:38:05 +01:00
{
2018-03-31 23:39:08 +02:00
print '<div class="inline-block divButAction"><a class="butAction' . ( $conf -> use_javascript_ajax ? ' reposition' : '' ) . '" href="' . $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id . '&action=canceled">' . $langs -> trans ( 'ClassifyCanceled' ) . '</a></div>' ;
2016-03-24 11:38:05 +01:00
}
2013-04-20 00:10:20 +02:00
}
2013-11-17 23:25:25 +01:00
}
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Clone
2018-11-14 14:59:36 +01:00
if (( $object -> type == Facture :: TYPE_STANDARD || $object -> type == Facture :: TYPE_DEPOSIT || $object -> type == Facture :: TYPE_PROFORMA ) && $usercancreate )
2013-11-17 23:25:25 +01:00
{
2018-03-31 23:39:08 +02:00
print '<div class="inline-block divButAction"><a class="butAction' . ( $conf -> use_javascript_ajax ? ' reposition' : '' ) . '" href="' . $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id . '&action=clone&object=invoice">' . $langs -> trans ( " ToClone " ) . '</a></div>' ;
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2016-02-11 10:39:01 +01:00
// Clone as predefined / Create template
2018-11-14 14:59:36 +01:00
if (( $object -> type == Facture :: TYPE_STANDARD || $object -> type == Facture :: TYPE_DEPOSIT || $object -> type == Facture :: TYPE_PROFORMA ) && $object -> statut == 0 && $usercancreate )
2013-11-17 23:25:25 +01:00
{
2016-02-11 10:39:01 +01:00
if ( ! $objectidnext && count ( $object -> lines ) > 0 )
2013-11-17 23:25:25 +01:00
{
2017-07-13 16:56:36 +02:00
print '<div class="inline-block divButAction"><a class="butAction" href="' . DOL_URL_ROOT . '/compta/facture/fiche-rec.php?facid=' . $object -> id . '&action=create">' . $langs -> trans ( " ChangeIntoRepeatableInvoice " ) . '</a></div>' ;
2013-04-20 17:10:03 +02:00
}
}
2016-07-19 07:46:27 +02:00
2015-07-08 14:01:30 +02:00
// Create a credit note
2018-11-14 14:59:36 +01:00
if (( $object -> type == Facture :: TYPE_STANDARD || $object -> type == Facture :: TYPE_DEPOSIT || $object -> type == Facture :: TYPE_PROFORMA ) && $object -> statut > 0 && $usercancreate )
2015-07-08 14:01:30 +02:00
{
if ( ! $objectidnext )
{
2016-09-11 13:30:14 +02:00
print '<div class="inline-block divButAction"><a class="butAction" href="' . $_SERVER [ 'PHP_SELF' ] . '?socid=' . $object -> socid . '&fac_avoir=' . $object -> id . '&action=create&type=2' . ( $object -> fk_project > 0 ? '&projectid=' . $object -> fk_project : '' ) . '">' . $langs -> trans ( " CreateCreditNote " ) . '</a></div>' ;
2015-07-08 14:01:30 +02:00
}
}
2014-03-01 19:45:13 +01:00
2018-03-22 11:19:39 +01:00
// For situation invoice with excess received
2018-07-24 17:49:10 +02:00
if ( $object -> statut > Facture :: STATUS_DRAFT
2018-03-22 11:19:39 +01:00
&& ( $object -> total_ttc - $totalpaye - $totalcreditnotes - $totaldeposits ) > 0
2018-11-14 14:59:36 +01:00
&& $usercancreate
2018-03-22 11:19:39 +01:00
&& ! $objectidnext
&& $object -> is_last_in_cycle ()
2018-05-16 16:15:30 +02:00
&& $conf -> global -> INVOICE_USE_SITUATION_CREDIT_NOTE
2018-03-22 11:19:39 +01:00
)
{
2018-11-14 14:59:36 +01:00
if ( $usercanunvalidate )
2018-03-22 11:19:39 +01:00
{
print '<div class="inline-block divButAction"><a class="butAction" href="' . $_SERVER [ 'PHP_SELF' ] . '?socid=' . $object -> socid . '&fac_avoir=' . $object -> id . '&invoiceAvoirWithLines=1&action=create&type=2' . ( $object -> fk_project > 0 ? '&projectid=' . $object -> fk_project : '' ) . '">' . $langs -> trans ( " CreateCreditNote " ) . '</a></div>' ;
} else {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><span class="butActionRefused classfortooltip" title="' . $langs -> trans ( " NotEnoughPermissions " ) . '">' . $langs -> trans ( " CreateCreditNote " ) . '</span></div>' ;
2018-05-23 08:16:24 +02:00
}
2018-03-22 11:19:39 +01:00
}
2018-05-23 08:16:24 +02:00
2018-04-03 15:12:44 +02:00
// remove situation from cycle
2018-07-24 17:49:10 +02:00
if ( $object -> statut > Facture :: STATUS_DRAFT
2018-04-05 09:46:55 +02:00
&& $object -> type == Facture :: TYPE_SITUATION
2018-11-14 14:59:36 +01:00
&& $usercancreate
2018-04-03 15:12:44 +02:00
&& ! $objectidnext
2018-04-03 17:34:20 +02:00
&& $object -> situation_counter > 1
2018-04-03 15:12:44 +02:00
&& $object -> is_last_in_cycle ()
2018-11-14 14:59:36 +01:00
&& $usercanunvalidate
2018-04-03 15:12:44 +02:00
)
{
2018-04-04 12:33:48 +02:00
if (( $object -> total_ttc - $totalcreditnotes ) == 0 )
2018-04-03 15:12:44 +02:00
{
2018-04-03 17:34:20 +02:00
print '<div class="inline-block divButAction"><a id="butSituationOut" class="butAction" href="' . $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id . '&action=situationout">' . $langs -> trans ( " RemoveSituationFromCycle " ) . '</a></div>' ;
2018-04-03 15:12:44 +02:00
}
2018-05-23 08:16:24 +02:00
else
2018-04-03 15:12:44 +02:00
{
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><a id="butSituationOutRefused" class="butActionRefused classfortooltip" href="#" title="' . $langs -> trans ( " DisabledBecauseNotEnouthCreditNote " ) . '" >' . $langs -> trans ( " RemoveSituationFromCycle " ) . '</a></div>' ;
2018-04-03 15:12:44 +02:00
}
}
2018-05-23 08:16:24 +02:00
2016-02-11 10:39:01 +01:00
// Create next situation invoice
2018-11-14 14:59:36 +01:00
if ( $usercancreate && ( $object -> type == 5 ) && ( $object -> statut == 1 || $object -> statut == 2 )) {
2014-11-14 16:43:49 +01:00
if ( $object -> is_last_in_cycle () && $object -> situation_final != 1 ) {
print '<div class="inline-block divButAction"><a class="butAction" href="' . $_SERVER [ 'PHP_SELF' ] . '?action=create&type=5&origin=facture&originid=' . $object -> id . '&socid=' . $object -> socid . '" >' . $langs -> trans ( 'CreateNextSituationInvoice' ) . '</a></div>' ;
} else if ( ! $object -> is_last_in_cycle ()) {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="' . $langs -> trans ( " DisabledBecauseNotLastInCycle " ) . '">' . $langs -> trans ( 'CreateNextSituationInvoice' ) . '</a></div>' ;
2014-11-14 16:43:49 +01:00
} else {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="' . $langs -> trans ( " DisabledBecauseFinal " ) . '">' . $langs -> trans ( 'CreateNextSituationInvoice' ) . '</a></div>' ;
2014-11-14 16:43:49 +01:00
}
}
2013-11-17 23:25:25 +01:00
// Delete
2018-10-29 14:35:42 +01:00
$isErasable = $object -> is_erasable ();
2018-11-14 14:59:36 +01:00
if ( $usercandelete || ( $usercancreate && $isErasable == 1 )) // isErasable = 1 means draft with temporary ref (draft can always be deleted with no need of permissions)
2013-11-17 23:25:25 +01:00
{
2017-12-05 10:01:30 +01:00
//var_dump($isErasable);
if ( $isErasable == - 4 ) {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="' . $langs -> trans ( " DisabledBecausePayments " ) . '">' . $langs -> trans ( 'Delete' ) . '</a></div>' ;
2017-12-05 10:01:30 +01:00
}
elseif ( $isErasable == - 3 ) {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="' . $langs -> trans ( " DisabledBecauseNotLastSituationInvoice " ) . '">' . $langs -> trans ( 'Delete' ) . '</a></div>' ;
2017-12-05 10:01:30 +01:00
}
elseif ( $isErasable == - 2 ) {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="' . $langs -> trans ( " DisabledBecauseNotLastInvoice " ) . '">' . $langs -> trans ( 'Delete' ) . '</a></div>' ;
2017-12-05 10:01:30 +01:00
}
elseif ( $isErasable == - 1 ) {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="' . $langs -> trans ( " DisabledBecauseDispatchedInBookkeeping " ) . '">' . $langs -> trans ( 'Delete' ) . '</a></div>' ;
2017-12-05 10:01:30 +01:00
}
elseif ( $isErasable <= 0 ) // Any other cases
{
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="' . $langs -> trans ( " DisabledBecauseNotErasable " ) . '">' . $langs -> trans ( 'Delete' ) . '</a></div>' ;
2017-12-05 10:01:30 +01:00
}
elseif ( $objectidnext )
{
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="' . $langs -> trans ( " DisabledBecauseReplacedInvoice " ) . '">' . $langs -> trans ( 'Delete' ) . '</a></div>' ;
2017-12-05 10:01:30 +01:00
}
else
{
2018-03-31 23:39:08 +02:00
print '<div class="inline-block divButAction"><a class="butActionDelete' . ( $conf -> use_javascript_ajax ? ' reposition' : '' ) . '" href="' . $_SERVER [ " PHP_SELF " ] . '?facid=' . $object -> id . '&action=delete">' . $langs -> trans ( 'Delete' ) . '</a></div>' ;
2013-11-17 23:25:25 +01:00
}
2014-02-23 20:10:05 +01:00
} else {
2018-11-13 21:40:17 +01:00
print '<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="' . $langs -> trans ( " NotAllowed " ) . '">' . $langs -> trans ( 'Delete' ) . '</a></div>' ;
2013-11-17 23:25:25 +01:00
}
}
2017-12-10 15:24:47 +01:00
print '</div>' ;
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2015-05-27 07:41:25 +02:00
// Select mail models is same action as presend
2017-09-02 12:36:22 +02:00
if ( GETPOST ( 'modelselected' , 'alpha' )) {
2015-04-18 17:15:36 +02:00
$action = 'presend' ;
}
2013-11-17 23:25:25 +01:00
if ( $action != 'prerelance' && $action != 'presend' )
{
print '<div class="fichecenter"><div class="fichehalfleft">' ;
print '<a name="builddoc"></a>' ; // ancre
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// Documents generes
2014-02-23 20:10:05 +01:00
$filename = dol_sanitizeFileName ( $object -> ref );
$filedir = $conf -> facture -> dir_output . '/' . dol_sanitizeFileName ( $object -> ref );
2014-05-12 12:10:52 +02:00
$urlsource = $_SERVER [ 'PHP_SELF' ] . '?facid=' . $object -> id ;
2018-11-14 14:59:36 +01:00
$genallowed = $usercanread ;
$delallowed = $usercancreate ;
2014-03-01 19:45:13 +01:00
2014-02-23 20:10:05 +01:00
print $formfile -> showdocuments ( 'facture' , $filename , $filedir , $urlsource , $genallowed , $delallowed , $object -> modelpdf , 1 , 0 , 0 , 28 , 0 , '' , '' , '' , $soc -> default_lang );
$somethingshown = $formfile -> numoffiles ;
2014-03-01 19:45:13 +01:00
2015-06-06 15:57:59 +02:00
// Show links to link elements
2016-08-04 11:57:37 +02:00
$linktoelem = $form -> showLinkToObjectBlock ( $object , null , array ( 'invoice' ));
2018-04-10 12:03:01 +02:00
2018-02-22 15:19:20 +01:00
$compatibleImportElementsList = false ;
2018-11-14 14:59:36 +01:00
if ( $usercancreate
2018-04-10 12:03:01 +02:00
&& $object -> statut == Facture :: STATUS_DRAFT
2018-02-22 15:19:20 +01:00
&& ( $object -> type == Facture :: TYPE_STANDARD || $object -> type == Facture :: TYPE_REPLACEMENT || $object -> type == Facture :: TYPE_DEPOSIT || $object -> type == Facture :: TYPE_PROFORMA || $object -> type == Facture :: TYPE_SITUATION ) )
{
2018-05-10 21:06:18 +02:00
$compatibleImportElementsList = array ( 'commande' , 'propal' ); // import from linked elements
2018-02-22 15:19:20 +01:00
}
$somethingshown = $form -> showLinkedObjectBlock ( $object , $linktoelem , $compatibleImportElementsList );
2018-04-10 12:03:01 +02:00
2017-02-22 06:33:52 +01:00
2017-09-12 12:18:26 +02:00
// Show online payment link
$useonlinepayment = ( ! empty ( $conf -> paypal -> enabled ) || ! empty ( $conf -> stripe -> enabled ) || ! empty ( $conf -> paybox -> enabled ));
2017-10-19 11:14:31 +02:00
if ( $object -> statut != Facture :: STATUS_DRAFT && $useonlinepayment )
2017-09-12 12:18:26 +02:00
{
2017-11-04 17:11:58 +01:00
print '<br><!-- Link to pay -->' . " \n " ;
2017-09-12 12:18:26 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/lib/payments.lib.php' ;
2017-11-04 17:11:58 +01:00
print showOnlinePaymentUrl ( 'invoice' , $object -> ref ) . '<br>' ;
}
2018-01-08 13:21:04 +01:00
// Show direct download link
2017-11-04 17:11:58 +01:00
if ( $object -> statut != Facture :: STATUS_DRAFT && ! empty ( $conf -> global -> INVOICE_ALLOW_EXTERNAL_DOWNLOAD ))
{
print '<br><!-- Link to download main doc -->' . " \n " ;
print showDirectDownloadLink ( $object ) . '<br>' ;
2013-11-17 23:25:25 +01:00
}
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
print '</div><div class="fichehalfright"><div class="ficheaddleft">' ;
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
// List of actions on element
2014-02-23 20:10:05 +01:00
include_once DOL_DOCUMENT_ROOT . '/core/class/html.formactions.class.php' ;
$formactions = new FormActions ( $db );
2017-09-13 14:18:36 +02:00
$somethingshown = $formactions -> showactions ( $object , 'invoice' , $socid , 1 );
2014-03-01 19:45:13 +01:00
2013-11-17 23:25:25 +01:00
print '</div></div></div>' ;
2014-08-06 00:46:00 +02:00
}
2014-07-28 02:45:58 +02:00
2014-03-01 19:45:13 +01:00
2017-09-17 15:38:50 +02:00
// Presend form
$modelmail = 'facture_send' ;
$defaulttopic = 'SendBillRef' ;
$diroutput = $conf -> facture -> dir_output ;
$trackid = 'inv' . $object -> id ;
2014-03-01 19:45:13 +01:00
2017-09-17 15:38:50 +02:00
include DOL_DOCUMENT_ROOT . '/core/tpl/card_presend.tpl.php' ;
2013-04-20 17:10:03 +02:00
}
2008-08-12 20:20:18 +02:00
2018-07-30 17:28:44 +02:00
// End of page
2013-04-20 17:10:03 +02:00
llxFooter ();
$db -> close ();