46require
'../../main.inc.php';
47require_once DOL_DOCUMENT_ROOT.
'/categories/class/categorie.class.php';
48require_once DOL_DOCUMENT_ROOT.
'/compta/facture/class/facture.class.php';
49require_once DOL_DOCUMENT_ROOT.
'/compta/facture/class/facture-rec.class.php';
50require_once DOL_DOCUMENT_ROOT.
'/compta/bank/class/account.class.php';
51require_once DOL_DOCUMENT_ROOT.
'/compta/paiement/class/paiement.class.php';
52require_once DOL_DOCUMENT_ROOT.
'/core/modules/facture/modules_facture.php';
53require_once DOL_DOCUMENT_ROOT.
'/core/class/discount.class.php';
54require_once DOL_DOCUMENT_ROOT.
'/core/class/extrafields.class.php';
55require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formfile.class.php';
56require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formother.class.php';
57require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formmargin.class.php';
58require_once DOL_DOCUMENT_ROOT.
'/core/lib/invoice.lib.php';
59require_once DOL_DOCUMENT_ROOT.
'/core/lib/functions2.lib.php';
60require_once DOL_DOCUMENT_ROOT.
'/core/lib/date.lib.php';
61if (isModEnabled(
'order')) {
62 require_once DOL_DOCUMENT_ROOT.
'/commande/class/commande.class.php';
64if (isModEnabled(
'project')) {
65 require_once DOL_DOCUMENT_ROOT.
'/projet/class/project.class.php';
66 require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formprojet.class.php';
68require_once DOL_DOCUMENT_ROOT.
'/core/class/doleditor.class.php';
70if (isModEnabled(
'variants')) {
71 require_once DOL_DOCUMENT_ROOT.
'/variants/class/ProductCombination.class.php';
73if (isModEnabled(
'accounting')) {
74 require_once DOL_DOCUMENT_ROOT.
'/accountancy/class/accountingjournal.class.php';
87$langs->loadLangs(array(
'bills',
'companies',
'compta',
'products',
'banks',
'main',
'withdrawals'));
88if (isModEnabled(
'incoterm')) {
89 $langs->load(
'incoterm');
91if (isModEnabled(
'margin')) {
92 $langs->load(
'margins');
99$action =
GETPOST(
'action',
'aZ09');
100$confirm =
GETPOST(
'confirm',
'alpha');
101$cancel =
GETPOST(
'cancel',
'alpha');
102$backtopage =
GETPOST(
'backtopage',
'alpha');
103$backtopageforcancel =
GETPOST(
'backtopageforcancel',
'alpha');
106$search_ref =
GETPOST(
'sf_ref',
'alpha') ?
GETPOST(
'sf_ref',
'alpha') :
GETPOST(
'search_ref',
'alpha');
107$search_societe =
GETPOST(
'search_societe',
'alpha');
108$search_montant_ht =
GETPOST(
'search_montant_ht',
'alpha');
109$search_montant_ttc =
GETPOST(
'search_montant_ttc',
'alpha');
110$origin =
GETPOST(
'origin',
'alpha');
114$ref_client =
GETPOST(
'ref_client',
'alpha');
115$inputReasonId =
GETPOSTINT(
'input_reason_id');
118$selectedLines =
GETPOST(
'toselect',
'array');
134$extrafields->fetch_name_optionals_label(
$object->table_element);
137$total_global_ttc = 0;
138$displayWarranty =
false;
139$statusreplacement = 0;
141$price_base_type =
'';
142$array_options = array();
145if ($id > 0 || !empty($ref)) {
146 if ($action !=
'add') {
148 $fetch_situation =
false;
150 $fetch_situation =
true;
152 $ret =
$object->fetch($id, $ref,
'', 0, $fetch_situation);
153 if ($ret > 0 && isset(
$object->fk_project)) {
154 $ret =
$object->fetchProject();
160$hookmanager->initHooks(array(
'invoicecard',
'globalcard'));
163$usercanread = $user->hasRight(
"facture",
"lire");
164$usercancreate = $user->hasRight(
"facture",
"creer");
165$usercanissuepayment = $user->hasRight(
"facture",
"paiement");
166$usercandelete = $user->hasRight(
"facture",
"supprimer") || ($usercancreate && isset(
$object->status) &&
$object->status == $object::STATUS_DRAFT);
167$usercancreatecontract = $user->hasRight(
"contrat",
"creer");
170$usercanvalidate = ((!
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $usercancreate) || (
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $user->hasRight(
'facture',
'invoice_advance',
'validate')));
171$usercansend = ((!
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $usercanread) || (
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $user->hasRight(
'facture',
'invoice_advance',
'send')));
172$usercanreopen = ((!
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $usercancreate) || (
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $user->hasRight(
'facture',
'invoice_advance',
'reopen')));
174 $usercanreopen =
false;
176$usercanunvalidate = ((!
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && !empty($usercancreate)) || (
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $user->hasRight(
'facture',
'invoice_advance',
'unvalidate')));
177$usermustrespectpricemin = ((
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && !$user->hasRight(
'produit',
'ignore_price_min_advance')) || !
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS'));
180$usercancreatemargin = $user->hasRight(
'margins',
'creer');
181$usercanreadallmargin = $user->hasRight(
'margins',
'liretous');
182$usercancreatewithdrarequest = $user->hasRight(
'prelevement',
'bons',
'creer');
184$permissionnote = $usercancreate;
185$permissiondellink = $usercancreate;
186$permissiontoedit = $usercancreate;
187$permissiontoadd = $usercancreate;
188$permissiontoeditextra = $usercancreate;
189if (
GETPOST(
'attribute',
'aZ09') && isset($extrafields->attributes[
$object->table_element][
'perms'][
GETPOST(
'attribute',
'aZ09')])) {
191 $permissiontoeditextra =
dol_eval((
string) $extrafields->attributes[
$object->table_element][
'perms'][
GETPOST(
'attribute',
'aZ09')]);
195$retainedWarrantyInvoiceAvailableType = array();
197 $retainedWarrantyInvoiceAvailableType = explode(
'+',
getDolGlobalString(
'INVOICE_USE_RETAINED_WARRANTY'));
202 $socid = $user->socid;
215$parameters = array(
'socid' => $socid);
216$reshook = $hookmanager->executeHooks(
'doActions', $parameters,
$object, $action);
221if (empty($reshook)) {
222 $backurlforlist = DOL_URL_ROOT.
'/compta/facture/list.php';
224 if (empty($backtopage) || ($cancel && empty($id))) {
225 if (empty($backtopage) || ($cancel && strpos($backtopage,
'__ID__'))) {
226 if (empty($id) && (($action !=
'add' && $action !=
'create') || $cancel)) {
227 $backtopage = $backurlforlist;
229 $backtopage = DOL_URL_ROOT.
'/compta/facture/card.php?id='.((!empty($id) &&
$id > 0) ? $id :
'__ID__');
235 if (!empty($backtopageforcancel)) {
236 header(
"Location: ".$backtopageforcancel);
238 } elseif (!empty($backtopage)) {
239 header(
"Location: ".$backtopage);
245 include DOL_DOCUMENT_ROOT.
'/core/actions_setnotes.inc.php';
247 include DOL_DOCUMENT_ROOT.
'/core/actions_dellink.inc.php';
249 include DOL_DOCUMENT_ROOT.
'/core/actions_lineupdown.inc.php';
252 if ($action ==
'confirm_clone' && $confirm ==
'yes' && $permissiontoadd) {
254 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'IdThirdParty')),
null,
'errors');
257 '@phan-var-force Facture $objectutil';
260 $objectutil->socid = $socid;
261 $result = $objectutil->createFromClone($user, $id);
263 $warningMsgLineList = array();
265 foreach ($objectutil->lines as $line) {
266 if (!is_object($line->product)) {
267 $line->fetch_product();
269 if (is_object($line->product) && $line->product->id > 0) {
270 if (empty($line->product->status)) {
271 $warningMsgLineList[$line->id] = $langs->trans(
'WarningLineProductNotToSell', $line->product->ref);
275 if (!empty($warningMsgLineList)) {
279 header(
"Location: " . $_SERVER[
'PHP_SELF'] .
'?facid=' . $result);
282 $langs->load(
"errors");
287 } elseif ($action ==
'reopen' && $usercanreopen) {
291 $result =
$object->setUnpaid($user);
293 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
299 } elseif ($action ==
'confirm_delete' && $confirm ==
'yes' && $usercandelete) {
304 $idwarehouse =
GETPOST(
'idwarehouse');
306 $qualified_for_stock_change = 0;
308 $qualified_for_stock_change =
$object->hasProductsOrServices(2);
310 $qualified_for_stock_change =
$object->hasProductsOrServices(1);
313 $isErasable =
$object->is_erasable();
315 if (($isErasable > 0) || ($usercancreate && $isErasable == 1)) {
316 $result =
$object->delete($user, 0, (
int) $idwarehouse);
318 header(
'Location: '.DOL_URL_ROOT.
'/compta/facture/list.php?restore_lastsearch_values=1');
325 } elseif ($action ==
'confirm_deleteline' && $confirm ==
'yes' && $usercancreate) {
335 $outputlangs = $langs;
341 $newlang =
$object->thirdparty->default_lang;
343 if (!empty($newlang)) {
345 $outputlangs->setDefaultLang($newlang);
346 $outputlangs->load(
'products');
350 $result =
$object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
353 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
360 } elseif ($action ==
'confirm_delete_subtotalline' && $confirm ==
'yes' && $usercancreate) {
365 $result =
$object->deleteSubtotalLine($langs,
GETPOSTINT(
'lineid'), (
bool)
GETPOST(
'deletecorrespondingsubtotalline'));
370 $outputlangs = $langs;
376 $newlang =
$object->thirdparty->default_lang;
378 if (!empty($newlang)) {
380 $outputlangs->setDefaultLang($newlang);
381 $outputlangs->load(
'products');
385 $result =
$object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
388 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
395 } elseif ($action ==
'unlinkdiscount' && $usercancreate) {
398 $result = $discount->fetch(
GETPOSTINT(
"discountid"));
399 $discount->unlink_invoice();
400 } elseif ($action ==
'valid' && $usercancreate) {
404 if ((preg_match(
'/^[\(]?PROV/i',
$object->ref) || empty(
$object->ref)) &&
411 $last_of_type =
$object->willBeLastOfSameType(
true);
412 if (empty(
$object->date_validation) && !$last_of_type[0]) {
422 setEventMessages($langs->trans(
"ErrorInvoiceAvoirMustBeNegative"),
null,
'errors');
431 setEventMessages($langs->trans(
"ErrorInvoiceOfThisTypeMustBePositive"),
null,
'errors');
440 $array_of_total_ht_per_vat_rate = array();
441 $array_of_total_ht_devise_per_vat_rate = array();
442 foreach (
$object->lines as $line) {
444 $vat_src_code_for_line =
'';
445 if (empty($array_of_total_ht_per_vat_rate[$line->tva_tx.
'_'.$vat_src_code_for_line])) {
446 $array_of_total_ht_per_vat_rate[$line->tva_tx.
'_'.$vat_src_code_for_line] = 0;
448 if (empty($array_of_total_ht_devise_per_vat_rate[$line->tva_tx.
'_'.$vat_src_code_for_line])) {
449 $array_of_total_ht_devise_per_vat_rate[$line->tva_tx.
'_'.$vat_src_code_for_line] = 0;
451 $array_of_total_ht_per_vat_rate[$line->tva_tx.
'_'.$vat_src_code_for_line] += $line->total_ht;
452 $array_of_total_ht_devise_per_vat_rate[$line->tva_tx.
'_'.$vat_src_code_for_line] += $line->multicurrency_total_ht;
456 foreach ($array_of_total_ht_per_vat_rate as $vatrate => $tmpvalue) {
457 $tmp_total_ht =
price2num($array_of_total_ht_per_vat_rate[$vatrate]);
458 $tmp_total_ht_devise =
price2num($array_of_total_ht_devise_per_vat_rate[$vatrate]);
460 if (($tmp_total_ht < 0 || $tmp_total_ht_devise < 0) && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES')) {
461 if (
$object->type == $object::TYPE_DEPOSIT) {
462 $langs->load(
"errors");
464 setEventMessages($langs->trans(
"ErrorLinesCantBeNegativeOnDeposits"),
null,
'errors');
468 $tmpvatratetoshow = explode(
'_', $vatrate);
469 $tmpvatratetoshow[0] = round((
float) $tmpvatratetoshow[0], 2);
471 if ($tmpvatratetoshow[0] != 0) {
472 $langs->load(
"errors");
473 setEventMessages($langs->trans(
"ErrorLinesCantBeNegativeForOneVATRate", (
string) $tmpvatratetoshow[0]),
null,
'errors');
481 } elseif ($action ==
'classin' && $usercancreate) {
484 } elseif ($action ==
'setposinfo' && $usercancreate) {
488 $result =
$object->update($user);
492 } elseif ($action ==
'setmode' && $usercancreate) {
498 } elseif ($action ==
'setretainedwarrantyconditions' && $usercancreate) {
500 $object->retained_warranty_fk_cond_reglement = 0;
501 $result =
$object->setRetainedWarrantyPaymentTerms(
GETPOSTINT(
'retained_warranty_fk_cond_reglement'));
506 $old_rw_date_lim_reglement =
$object->retained_warranty_date_limit;
507 $new_rw_date_lim_reglement =
$object->calculate_date_lim_reglement(
$object->retained_warranty_fk_cond_reglement);
508 if ($new_rw_date_lim_reglement > $old_rw_date_lim_reglement) {
509 $object->retained_warranty_date_limit = $new_rw_date_lim_reglement;
514 $result =
$object->update($user);
518 } elseif ($action ==
'setretainedwarranty' && $usercancreate) {
524 } elseif ($action ==
'setretainedwarrantydatelimit' && $usercancreate) {
526 $result =
$object->setRetainedWarrantyDateLimit(
GETPOSTINT(
'retained_warranty_date_limit'));
530 } elseif ($action ==
'setmulticurrencycode' && $usercancreate) {
531 $result =
$object->setMulticurrencyCode(
GETPOST(
'multicurrency_code',
'alpha'));
532 } elseif ($action ==
'setmulticurrencyrate' && $usercancreate) {
534 } elseif ($action ==
'setinvoicedate' && $usercancreate) {
536 $old_date_lim_reglement =
$object->date_lim_reglement;
538 if (empty($newdate)) {
539 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Date")),
null,
'errors');
540 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.
$id.
'&action=editinvoicedate&token='.
newToken());
545 setEventMessages($langs->trans(
"WarningInvoiceDateInFuture"),
null,
'warnings');
547 setEventMessages($langs->trans(
"WarningInvoiceDateTooFarInFuture"),
null,
'warnings');
552 $new_date_lim_reglement =
$object->calculate_date_lim_reglement();
553 if ($new_date_lim_reglement) {
554 $object->date_lim_reglement = $new_date_lim_reglement;
559 $result =
$object->update($user);
562 $action =
'editinvoicedate';
564 } elseif ($action ==
'setdate_pointoftax' && $usercancreate) {
569 $object->date_pointoftax = $date_pointoftax;
570 $result =
$object->update($user);
574 } elseif ($action ==
'setconditions' && $usercancreate) {
576 $object->cond_reglement_code = 0;
577 $object->cond_reglement_id = 0;
590 $old_date_lim_reglement =
$object->date_lim_reglement;
591 $new_date_lim_reglement =
$object->calculate_date_lim_reglement();
592 if ($new_date_lim_reglement) {
593 $object->date_lim_reglement = $new_date_lim_reglement;
598 $result =
$object->update($user);
610 } elseif ($action ==
'setpaymentterm' && $usercancreate) {
614 $object->date_lim_reglement =
$object->calculate_date_lim_reglement();
615 setEventMessages($langs->trans(
"DatePaymentTermCantBeLowerThanObjectDate"),
null,
'warnings');
617 $result =
$object->update($user);
621 } elseif ($action ==
'setrevenuestamp' && $usercancreate) {
624 $result =
$object->update($user);
631 $outputlangs = $langs;
634 $newlang =
GETPOST(
'lang_id',
'aZ09');
637 $newlang =
$object->thirdparty->default_lang;
639 if (!empty($newlang)) {
641 $outputlangs->setDefaultLang($newlang);
642 $outputlangs->load(
'products');
647 $result =
$object->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
653 } elseif ($action ==
'set_incoterms' && isModEnabled(
'incoterm') && $usercancreate) {
655 } elseif ($action ==
'settags' && isModEnabled(
'category') && $usercancreate) {
657 } elseif ($action ==
'setbankaccount' && $usercancreate) {
659 } elseif ($action ==
'setremisepercent' && $usercancreate) {
662 } elseif ($action ==
'setabsolutediscount' && $usercancreate) {
681 $newremaintopay =
$object->getRemainToPay(0);
682 if ($newremaintopay == 0) {
689 if (
GETPOSTINT(
"remise_id_for_payment") > 0) {
690 require_once DOL_DOCUMENT_ROOT.
'/core/class/discount.class.php';
692 $discount->fetch(
GETPOSTINT(
"remise_id_for_payment"));
696 $remaintopay =
$object->getRemainToPay(0);
700 setEventMessages($langs->trans(
"ErrorDiscountLargerThanRemainToPaySplitItBefore"),
null,
'errors');
704 $result = $discount->link_to_invoice(0, $id);
712 $newremaintopay =
$object->getRemainToPay(0);
713 if ($newremaintopay == 0) {
726 $outputlangs = $langs;
729 $newlang =
GETPOST(
'lang_id',
'aZ09');
733 $newlang =
$object->thirdparty->default_lang;
735 if (!empty($newlang)) {
737 $outputlangs->setDefaultLang($newlang);
741 $result =
$object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
746 } elseif ($action ==
'setref' && $usercancreate) {
748 $object->setValueFrom(
'ref',
GETPOST(
'ref'),
'', 0,
'',
'', $user,
'BILL_MODIFY');
749 } elseif ($action ==
'setref_client' && $usercancreate) {
752 } elseif ($action ==
'setdemandreason' && $usercancreate) {
753 $result =
$object->setInputReason($inputReasonId);
757 } elseif ($action ==
'confirm_valid' && $confirm ==
'yes' && $usercanvalidate) {
766 $qualified_for_stock_change = 0;
768 $qualified_for_stock_change =
$object->hasProductsOrServices(2);
770 $qualified_for_stock_change =
$object->hasProductsOrServices(1);
773 if ($qualified_for_stock_change) {
774 if (!$idwarehouse || $idwarehouse == - 1) {
776 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
"Warehouse")),
null,
'errors');
783 $result =
$object->validate($user,
'', $idwarehouse);
787 $outputlangs = $langs;
790 $newlang =
GETPOST(
'lang_id',
'aZ09');
793 $newlang =
$object->thirdparty->default_lang;
795 if (!empty($newlang)) {
797 $outputlangs->setDefaultLang($newlang);
798 $outputlangs->load(
'products');
804 $result =
$object->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
817 } elseif ($action ==
'confirm_modif' && $usercanunvalidate && !
getDolGlobalString(
'INVOICE_CAN_NEVER_BE_EDITED')) {
826 $qualified_for_stock_change = 0;
828 $qualified_for_stock_change =
$object->hasProductsOrServices(2);
830 $qualified_for_stock_change =
$object->hasProductsOrServices(1);
833 if ($qualified_for_stock_change) {
834 if (!$idwarehouse || $idwarehouse == -1) {
836 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
"Warehouse")),
null,
'errors');
845 $sql =
'SELECT pf.amount';
846 $sql .=
' FROM ' . MAIN_DB_PREFIX .
'paiement_facture as pf';
847 $sql .=
' WHERE pf.fk_facture = ' . ((int)
$object->id);
849 $result = $db->query($sql);
852 $num = $db->num_rows($result);
855 $objp = $db->fetch_object($result);
856 $totalpaid += $objp->amount;
863 $resteapayer =
$object->total_ttc - $totalpaid;
866 $ventilExportCompta =
$object->getVentilExportCompta();
869 if ($ventilExportCompta == 0) {
871 $result =
$object->setDraft($user, $idwarehouse);
878 $outputlangs = $langs;
881 $newlang =
GETPOST(
'lang_id',
'aZ09');
884 $newlang =
$object->thirdparty->default_lang;
886 if (!empty($newlang)) {
888 $outputlangs->setDefaultLang($newlang);
889 $outputlangs->load(
'products');
894 $object->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
899 } elseif ($action ==
'confirm_paid' && $confirm ==
'yes' && $usercanissuepayment) {
902 $result =
$object->setPaid($user);
906 } elseif ($action ==
'confirm_paid_partially' && $confirm ==
'yes' && $usercanissuepayment) {
909 $close_code =
GETPOST(
"close_code",
'restricthtml');
910 $close_note =
GETPOST(
"close_note",
'restricthtml');
912 $result =
$object->setPaid($user, $close_code, $close_note);
919 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Reason")),
null,
'errors');
921 } elseif ($action ==
'confirm_canceled' && $confirm ==
'yes' && $usercancreate) {
924 $close_code =
GETPOST(
"close_code",
'restricthtml');
925 $close_note =
GETPOST(
"close_note",
'restricthtml');
927 $result =
$object->setCanceled($user, $close_code, $close_note);
934 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Reason")),
null,
'errors');
936 } elseif ($action ==
'confirm_converttoreduc' && $confirm ==
'yes' && $usercancreate) {
944 $result = $discountcheck->fetch(0,
$object->id);
957 $amount_ht = $amount_tva = $amount_ttc = array();
958 $multicurrency_amount_ht = $multicurrency_amount_tva = $multicurrency_amount_ttc = array();
962 foreach (
$object->lines as $line) {
963 if ($line->product_type < 9 && $line->total_ht != 0) {
964 $keyforvatrate = $line->tva_tx.($line->vat_src_code ?
' ('.$line->vat_src_code.
')' :
'');
966 if (!isset($amount_ht[$keyforvatrate])) {
967 $amount_ht[$keyforvatrate] = 0;
969 $amount_ht[$keyforvatrate] += $line->total_ht;
970 if (!isset($amount_tva[$keyforvatrate])) {
971 $amount_tva[$keyforvatrate] = 0;
973 $amount_tva[$keyforvatrate] += $line->total_tva;
974 if (!isset($amount_ttc[$keyforvatrate])) {
975 $amount_ttc[$keyforvatrate] = 0;
977 $amount_ttc[$keyforvatrate] += $line->total_ttc;
978 if (!isset($multicurrency_amount_ht[$keyforvatrate])) {
979 $multicurrency_amount_ht[$keyforvatrate] = 0;
981 $multicurrency_amount_ht[$keyforvatrate] += $line->multicurrency_total_ht;
982 if (!isset($multicurrency_amount_tva[$keyforvatrate])) {
983 $multicurrency_amount_tva[$keyforvatrate] = 0;
985 $multicurrency_amount_tva[$keyforvatrate] += $line->multicurrency_total_tva;
986 if (!isset($multicurrency_amount_ttc[$keyforvatrate])) {
987 $multicurrency_amount_ttc[$keyforvatrate] = 0;
989 $multicurrency_amount_ttc[$keyforvatrate] += $line->multicurrency_total_ttc;
993 '@phan-var-force array<string,float> $amount_ht
994 @phan-var-force array<string,float> $amount_tva
995 @phan-var-force array<string,float> $amount_ttc
996 @phan-var-force array<string,float> $multicurrency_amount_ht
997 @phan-var-force array<string,float> $multicurrency_amount_tva
998 @phan-var-force array<string,float> $multicurrency_amount_ttc';
1002 $alreadypaid =
$object->getSommePaiement();
1003 if ($alreadypaid && abs($alreadypaid) < abs(
$object->total_ttc)) {
1004 $ratio = abs((
$object->total_ttc - $alreadypaid) /
$object->total_ttc);
1005 foreach ($amount_ht as $vatrate => $val) {
1006 $amount_ht[$vatrate] =
price2num($amount_ht[$vatrate] * $ratio,
'MU');
1007 $amount_tva[$vatrate] =
price2num($amount_tva[$vatrate] * $ratio,
'MU');
1008 $amount_ttc[$vatrate] =
price2num($amount_ttc[$vatrate] * $ratio,
'MU');
1009 $multicurrency_amount_ht[$vatrate] =
price2num($multicurrency_amount_ht[$vatrate] * $ratio,
'MU');
1010 $multicurrency_amount_tva[$vatrate] =
price2num($multicurrency_amount_tva[$vatrate] * $ratio,
'MU');
1011 $multicurrency_amount_ttc[$vatrate] =
price2num($multicurrency_amount_ttc[$vatrate] * $ratio,
'MU');
1020 $discount->description =
'(CREDIT_NOTE)';
1022 $discount->description =
'(DEPOSIT)';
1024 $discount->description =
'(EXCESS RECEIVED)';
1026 setEventMessages($langs->trans(
'CantConvertToReducAnInvoiceOfThisType'),
null,
'errors');
1028 $discount->fk_soc =
$object->socid;
1029 $discount->socid =
$object->socid;
1030 $discount->fk_facture_source =
$object->id;
1039 $discount->description =
'(EXCESS RECEIVED)';
1042 $sql =
'SELECT SUM(pf.amount) as total_paiements';
1043 $sql .=
' FROM '.MAIN_DB_PREFIX.
'paiement_facture as pf, '.MAIN_DB_PREFIX.
'paiement as p';
1044 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_paiement as c ON p.fk_paiement = c.id';
1045 $sql .=
' WHERE pf.fk_facture = '.((int)
$object->id);
1046 $sql .=
' AND pf.fk_paiement = p.rowid';
1047 $sql .=
' AND p.entity IN ('.getEntity(
'invoice').
')';
1048 $resql = $db->query($sql);
1053 $res = $db->fetch_object($resql);
1054 $total_paiements = $res->total_paiements;
1057 $total_creditnote_and_deposit = 0;
1058 $sql =
"SELECT re.rowid, re.amount_ht, re.amount_tva, re.amount_ttc,";
1059 $sql .=
" re.description, re.fk_facture_source";
1060 $sql .=
" FROM ".MAIN_DB_PREFIX.
"societe_remise_except as re";
1061 $sql .=
" WHERE fk_facture = ".((int)
$object->id);
1062 $resql = $db->query($sql);
1063 if (!empty($resql)) {
1064 while ($obj = $db->fetch_object($resql)) {
1065 $total_creditnote_and_deposit += $obj->amount_ttc;
1071 $discount->amount_ttc =
price2num($total_paiements + $total_creditnote_and_deposit -
$object->total_ttc,
'MT');
1072 $discount->amount_tva = 0;
1073 $discount->amount_ht = $discount->amount_ttc;
1074 $discount->tva_tx = 0;
1075 $discount->vat_src_code =
'';
1077 if ($discount->amount_ttc > 0) {
1078 $result = $discount->create($user);
1088 $discount->description =
'(CREDIT_NOTE)';
1090 $discount->description =
'(DEPOSIT)';
1093 foreach ($amount_ht as $tva_tx => $xxx) {
1095 $discount->amount_ht = -((float) $amount_ht[$tva_tx]);
1096 $discount->amount_tva = -((float) $amount_tva[$tva_tx]);
1097 $discount->amount_ttc = -((float) $amount_ttc[$tva_tx]);
1098 $discount->total_ht = -((float) $amount_ht[$tva_tx]);
1099 $discount->total_tva = -((float) $amount_tva[$tva_tx]);
1100 $discount->total_ttc = -((float) $amount_ttc[$tva_tx]);
1101 $discount->multicurrency_amount_ht = -((float) $multicurrency_amount_ht[$tva_tx]);
1102 $discount->multicurrency_amount_tva = -((float) $multicurrency_amount_tva[$tva_tx]);
1103 $discount->multicurrency_amount_ttc = -((float) $multicurrency_amount_ttc[$tva_tx]);
1104 $discount->multicurrency_total_ht = -((float) $multicurrency_amount_ht[$tva_tx]);
1105 $discount->multicurrency_total_tva = -((float) $multicurrency_amount_tva[$tva_tx]);
1106 $discount->multicurrency_total_ttc = -((float) $multicurrency_amount_ttc[$tva_tx]);
1109 $discount->amount_ht = abs((
float) $amount_ht[$tva_tx]);
1110 $discount->amount_tva = abs((
float) $amount_tva[$tva_tx]);
1111 $discount->amount_ttc = abs((
float) $amount_ttc[$tva_tx]);
1112 $discount->total_ht = abs((
float) $amount_ht[$tva_tx]);
1113 $discount->total_tva = abs((
float) $amount_tva[$tva_tx]);
1114 $discount->total_ttc = abs((
float) $amount_ttc[$tva_tx]);
1115 $discount->multicurrency_amount_ht = abs((
float) $multicurrency_amount_ht[$tva_tx]);
1116 $discount->multicurrency_amount_tva = abs((
float) $multicurrency_amount_tva[$tva_tx]);
1117 $discount->multicurrency_amount_ttc = abs((
float) $multicurrency_amount_ttc[$tva_tx]);
1118 $discount->multicurrency_total_ht = abs((
float) $multicurrency_amount_ht[$tva_tx]);
1119 $discount->multicurrency_total_tva = abs((
float) $multicurrency_amount_tva[$tva_tx]);
1120 $discount->multicurrency_total_ttc = abs((
float) $multicurrency_amount_ttc[$tva_tx]);
1126 if (preg_match(
'/\((.*)\)/', $tva_tx, $reg)) {
1127 $vat_src_code = $reg[1];
1128 $tva_tx = preg_replace(
'/\s*\(.*\)/',
'', $tva_tx);
1131 $discount->tva_tx = abs((
float) $tva_tx);
1132 $discount->vat_src_code = $vat_src_code;
1134 $result = $discount->create($user);
1142 if (empty($error)) {
1152 $result =
$object->setPaid($user);
1166 } elseif ($action ==
'confirm_delete_paiement' && $confirm ==
'yes' && $usercanissuepayment) {
1171 $result = $paiement->fetch(
GETPOSTINT(
'paiement_id'));
1173 $result = $paiement->delete($user);
1175 header(
"Location: ".$_SERVER[
'PHP_SELF'].
"?id=".$id);
1183 } elseif ($action ==
'add' && $usercancreate) {
1190 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Type")),
null,
'errors');
1196 $object->demand_reason_id = $inputReasonId;
1198 $ret = $extrafields->setOptionalsFromPost(
null,
$object);
1208 if (empty($dateinvoice)) {
1210 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Date")),
null,
'errors');
1220 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"ReplaceInvoice")),
null,
'errors');
1230 $object->date_pointoftax = $date_pointoftax;
1231 $object->note_public = trim(
GETPOST(
'note_public',
'restricthtml'));
1232 $object->note_private = trim(
GETPOST(
'note_private',
'restricthtml'));
1243 $object->location_incoterms =
GETPOST(
'location_incoterms',
'alpha');
1244 $object->multicurrency_code =
GETPOST(
'multicurrency_code',
'alpha');
1261 if (!($sourceinvoice > 0) && !
getDolGlobalString(
'INVOICE_CREDIT_NOTE_STANDALONE')) {
1263 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"CorrectInvoice")),
null,
'errors');
1267 if (empty($dateinvoice)) {
1269 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Date")),
null,
'errors');
1279 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"InvoiceSubtype")),
null,
'errors');
1284 if (!empty($originentity)) {
1285 $object->entity = $originentity;
1291 $object->date_pointoftax = $date_pointoftax;
1292 $object->note_public = trim(
GETPOST(
'note_public',
'restricthtml'));
1293 $object->note_private = trim(
GETPOST(
'note_private',
'restricthtml'));
1298 $object->cond_reglement_id = 0;
1304 $object->location_incoterms =
GETPOST(
'location_incoterms',
'alpha');
1305 $object->multicurrency_code =
GETPOST(
'multicurrency_code',
'alpha');
1309 $object->fk_facture_source = $sourceinvoice > 0 ? $sourceinvoice :
'';
1312 $facture_source =
new Facture($db);
1313 if ($facture_source->fetch(
$object->fk_facture_source) > 0) {
1314 if ($facture_source->isSituationInvoice()) {
1315 $object->situation_counter = $facture_source->situation_counter;
1316 $object->situation_cycle_ref = $facture_source->situation_cycle_ref;
1317 $facture_source->fetchPreviousNextSituationInvoice();
1327 if (
$object->copy_linked_contact($facture_source,
'internal') < 0) {
1329 } elseif ($facture_source->socid ==
$object->socid) {
1331 if (
$object->copy_linked_contact($facture_source,
'external') < 0) {
1342 if (
GETPOSTINT(
'invoiceAvoirWithLines') == 1 && $id > 0) {
1343 if (!empty($facture_source->lines)) {
1344 $fk_parent_line = 0;
1346 foreach ($facture_source->lines as $line) {
1348 if (method_exists($line,
'fetch_optionals')) {
1350 $line->fetch_optionals();
1354 if (($line->product_type != 9 && empty($line->fk_parent_line)) || $line->product_type == 9) {
1355 $fk_parent_line = 0;
1359 if ($facture_source->isSituationInvoice()) {
1360 $source_fk_prev_id = $line->fk_prev_id;
1361 $line->fk_prev_id = $line->id;
1363 if (!empty($facture_source->tab_previous_situation_invoice)) {
1366 $tab_jumped_credit_notes = array();
1367 $lineIndex = count($facture_source->tab_previous_situation_invoice) - 1;
1368 $searchPreviousInvoice =
true;
1369 while ($searchPreviousInvoice) {
1370 if ($facture_source->tab_previous_situation_invoice[$lineIndex]->type ==
Facture::TYPE_SITUATION || $lineIndex < 1) {
1371 $searchPreviousInvoice =
false;
1375 $tab_jumped_credit_notes[$lineIndex] = $facture_source->tab_previous_situation_invoice[$lineIndex]->id;
1381 $maxPrevSituationPercent = 0;
1382 foreach ($facture_source->tab_previous_situation_invoice[$lineIndex]->lines as $prevLine) {
1383 if ($prevLine->id == $source_fk_prev_id) {
1384 $maxPrevSituationPercent = max($maxPrevSituationPercent, $prevLine->situation_percent);
1387 $line->total_ht -= $prevLine->total_ht;
1388 $line->total_tva -= $prevLine->total_tva;
1389 $line->total_ttc -= $prevLine->total_ttc;
1390 $line->total_localtax1 -= $prevLine->total_localtax1;
1391 $line->total_localtax2 -= $prevLine->total_localtax2;
1393 $line->multicurrency_subprice -= $prevLine->multicurrency_subprice;
1394 $line->multicurrency_total_ht -= $prevLine->multicurrency_total_ht;
1395 $line->multicurrency_total_tva -= $prevLine->multicurrency_total_tva;
1396 $line->multicurrency_total_ttc -= $prevLine->multicurrency_total_ttc;
1401 $line->situation_percent = $maxPrevSituationPercent - $line->situation_percent;
1406 $maxPrevSituationPercent = 0;
1407 foreach ($tab_jumped_credit_notes as $index => $creditnoteid) {
1408 foreach ($facture_source->tab_previous_situation_invoice[$index]->lines as $prevLine) {
1409 if ($prevLine->fk_prev_id == $source_fk_prev_id) {
1410 $maxPrevSituationPercent = $prevLine->situation_percent;
1412 $line->total_ht -= $prevLine->total_ht;
1413 $line->total_tva -= $prevLine->total_tva;
1414 $line->total_ttc -= $prevLine->total_ttc;
1415 $line->total_localtax1 -= $prevLine->total_localtax1;
1416 $line->total_localtax2 -= $prevLine->total_localtax2;
1418 $line->multicurrency_subprice -= $prevLine->multicurrency_subprice;
1419 $line->multicurrency_total_ht -= $prevLine->multicurrency_total_ht;
1420 $line->multicurrency_total_tva -= $prevLine->multicurrency_total_tva;
1421 $line->multicurrency_total_ttc -= $prevLine->multicurrency_total_ttc;
1427 $line->situation_percent += $maxPrevSituationPercent;
1433 $line->fk_facture =
$object->id;
1434 $line->fk_parent_line = $fk_parent_line;
1436 $line->subprice = -$line->subprice;
1438 $line->total_ht = -$line->total_ht;
1439 $line->total_tva = -$line->total_tva;
1440 $line->total_ttc = -$line->total_ttc;
1441 $line->total_localtax1 = -$line->total_localtax1;
1442 $line->total_localtax2 = -$line->total_localtax2;
1444 $line->multicurrency_subprice = -$line->multicurrency_subprice;
1445 $line->multicurrency_total_ht = -$line->multicurrency_total_ht;
1446 $line->multicurrency_total_tva = -$line->multicurrency_total_tva;
1447 $line->multicurrency_total_ttc = -$line->multicurrency_total_ttc;
1449 $line->context[
'createcreditnotefrominvoice'] = 1;
1450 $result = $line->insert(0, 1);
1455 if ($result > 0 && $line->product_type == 9) {
1456 $fk_parent_line = $result;
1464 if (
GETPOSTINT(
'invoiceAvoirWithPaymentRestAmount') == 1 && $id > 0) {
1465 if ($facture_source->fetch(
$object->fk_facture_source) > 0) {
1466 $totalpaid = $facture_source->getSommePaiement();
1467 $totalcreditnotes = $facture_source->getSumCreditNotesUsed();
1468 $totaldeposits = $facture_source->getSumDepositsUsed();
1469 $remain_to_pay = abs($facture_source->total_ttc - $totalpaid - $totalcreditnotes - $totaldeposits);
1471 if (
getDolGlobalString(
'INVOICE_VAT_TO_USE_ON_CREDIT_NOTE_WHEN_GENERATED_FROM_REMAIN_TO_PAY') ==
'default') {
1472 if ((empty(
$object->thirdparty) || !is_object(
$object->thirdparty) || get_class(
$object->thirdparty) !=
'Societe')) {
1475 if (!empty(
$object->thirdparty) && is_object(
$object->thirdparty) && get_class(
$object->thirdparty) ==
'Societe') {
1480 } elseif ((
float)
getDolGlobalString(
'INVOICE_VAT_TO_USE_ON_CREDIT_NOTE_WHEN_GENERATED_FROM_REMAIN_TO_PAY') > 0) {
1481 $tva_tx = (float)
getDolGlobalString(
'INVOICE_VAT_TO_USE_ON_CREDIT_NOTE_WHEN_GENERATED_FROM_REMAIN_TO_PAY');
1486 $object->addline($langs->trans(
'invoiceAvoirLineWithPaymentRestAmount'), 0, 1, $tva_tx, 0, 0, 0, 0,
'',
'', 0, 0, 0,
'TTC', $remain_to_pay);
1491 if (!empty(
$object->fk_facture_source) &&
$id > 0) {
1492 $facture_source->fetch(
$object->fk_facture_source);
1493 $facture_source->fetchObjectLinked();
1495 if (!empty($facture_source->linkedObjectsIds)) {
1496 foreach ($facture_source->linkedObjectsIds as $sourcetype => $TIds) {
1497 $object->add_object_linked($sourcetype, current($TIds));
1506 if (empty($dateinvoice)) {
1508 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Date")),
null,
'errors');
1519 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"InvoiceSubtype")),
null,
'errors');
1529 $object->date_pointoftax = $date_pointoftax;
1530 $object->note_public = trim(
GETPOST(
'note_public',
'restricthtml'));
1531 $object->note_private = trim(
GETPOST(
'note_private',
'restricthtml'));
1544 $object->location_incoterms =
GETPOST(
'location_incoterms',
'alpha');
1545 $object->multicurrency_code =
GETPOST(
'multicurrency_code',
'alpha');
1561 $typeamount =
GETPOST(
'typedeposit',
'aZ09');
1562 $valuestandardinvoice =
price2num(str_replace(
'%',
'',
GETPOST(
'valuestandardinvoice',
'alpha')),
'MU');
1563 $valuedeposit =
price2num(str_replace(
'%',
'',
GETPOST(
'valuedeposit',
'alpha')),
'MU');
1567 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Customer")),
null,
'errors');
1571 if (empty($dateinvoice)) {
1573 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Date")),
null,
'errors');
1583 if ($valuestandardinvoice < 0 || $valuestandardinvoice > 100) {
1584 setEventMessages($langs->trans(
"ErrorAPercentIsRequired"),
null,
'errors');
1589 if ($typeamount && !empty($origin) && !empty($originid)) {
1590 if ($typeamount ==
'amount' && $valuedeposit <= 0) {
1591 setEventMessages($langs->trans(
"ErrorAnAmountWithoutTaxIsRequired"),
null,
'errors');
1595 if ($typeamount ==
'variable' && $valuedeposit <= 0) {
1596 setEventMessages($langs->trans(
"ErrorAPercentIsRequired"),
null,
'errors');
1600 if ($typeamount ==
'variablealllines' && $valuedeposit <= 0) {
1601 setEventMessages($langs->trans(
"ErrorAPercentIsRequired"),
null,
'errors');
1611 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"InvoiceSubtype")),
null,
'errors');
1621 $object->date_pointoftax = $date_pointoftax;
1622 $object->note_public = trim(
GETPOST(
'note_public',
'restricthtml'));
1623 $object->note_private = trim(
GETPOST(
'note_private',
'restricthtml'));
1635 $object->location_incoterms =
GETPOST(
'location_incoterms',
'alpha');
1636 $object->multicurrency_code =
GETPOST(
'multicurrency_code',
'alpha');
1640 $object->situation_counter = 1;
1645 if (in_array(
$object->type, $retainedWarrantyInvoiceAvailableType)) {
1647 $object->retained_warranty_fk_cond_reglement =
GETPOSTINT(
'retained_warranty_fk_cond_reglement');
1649 $object->retained_warranty = 0;
1650 $object->retained_warranty_fk_cond_reglement = 0;
1653 $retained_warranty_date_limit =
GETPOST(
'retained_warranty_date_limit');
1654 if (!empty($retained_warranty_date_limit) &&
dol_stringtotime($retained_warranty_date_limit)) {
1657 $object->retained_warranty_date_limit = !empty(
$object->retained_warranty_date_limit) ?
$object->retained_warranty_date_limit :
$object->calculate_date_lim_reglement(
$object->retained_warranty_fk_cond_reglement);
1662 if (!empty($origin) && !empty($originid)) {
1665 $element = $subelement = $origin;
1666 if (preg_match(
'/^([^_]+)_([^_]+)/i', $origin, $regs)) {
1667 $element = $regs[1];
1668 $subelement = $regs[2];
1672 if ($element ==
'order') {
1673 $element = $subelement =
'commande';
1675 if ($element ==
'propal') {
1676 $element =
'comm/propal';
1677 $subelement =
'propal';
1679 if ($element ==
'contract') {
1680 $element = $subelement =
'contrat';
1682 if ($element ==
'inter') {
1683 $element = $subelement =
'fichinter';
1685 if ($element ==
'shipping') {
1686 $element = $subelement =
'expedition';
1690 $object->origin_type = $origin;
1691 $object->origin_id = $originid;
1696 if (
$object->origin ==
'shipping') {
1697 require_once DOL_DOCUMENT_ROOT.
'/expedition/class/expedition.class.php';
1699 $exp->fetch(
$object->origin_id);
1700 $exp->fetchObjectLinked();
1701 if (is_array($exp->linkedObjectsIds[
'commande']) && count($exp->linkedObjectsIds[
'commande']) > 0) {
1702 foreach ($exp->linkedObjectsIds[
'commande'] as $key => $value) {
1703 $object->linked_objects[
'commande'] = $value;
1709 $object->linked_objects = array_merge(
$object->linked_objects,
GETPOST(
'other_linked_objects',
'array:int'));
1717 $classname = ucfirst($subelement);
1718 $srcobject =
new $classname($db);
1719 '@phan-var-force CommonObject $srcobject';
1721 dol_syslog(
"Try to find source object origin=".
$object->origin.
" originid=".
$object->origin_id.
" to add lines or deposit lines");
1722 $result = $srcobject->fetch(
$object->origin_id);
1728 $amountdeposit = array();
1731 if ($typeamount ==
'amount') {
1732 $amount = (float) $valuedeposit;
1734 $amount = $srcobject->total_ttc * ((float) $valuedeposit / 100);
1737 $TTotalByTva = array();
1738 foreach ($srcobject->lines as &$line) {
1739 if (empty($line->qty)) {
1742 if (!empty($line->special_code)) {
1745 $TTotalByTva[$line->tva_tx] += $line->total_ttc;
1747 '@phan-var-force array<string,float> $TTotalByTva';
1749 $amount_ttc_diff = 0.;
1750 foreach ($TTotalByTva as $tva => &$total) {
1751 if (empty($amountdeposit[$tva])) {
1752 $amountdeposit[$tva] = 0;
1754 $coef = $total / $srcobject->total_ttc;
1755 $am = $amount * $coef;
1756 $amount_ttc_diff += $am;
1757 $amountdeposit[$tva] += $am / (1 + (float) $tva / 100);
1760 if ($typeamount ==
'amount') {
1761 $amountdeposit[0] = $valuedeposit;
1762 } elseif ($typeamount ==
'variable') {
1765 $lines = $srcobject->lines;
1766 $numlines = count($lines);
1767 for ($i = 0; $i < $numlines; $i++) {
1769 if (empty($lines[$i]->qty)) {
1772 if (!empty($lines[$i]->special_code)) {
1776 $totalamount += $lines[$i]->total_ht;
1777 $tva_tx = $lines[$i]->tva_tx;
1779 if (empty($amountdeposit[$tva_tx])) {
1780 $amountdeposit[$tva_tx] = 0;
1782 $amountdeposit[$tva_tx] += ($lines[$i]->total_ht * (float) $valuedeposit) / 100;
1786 if ($totalamount == 0) {
1787 $amountdeposit[0] = 0;
1795 $amount_ttc_diff = $amountdeposit[0];
1798 foreach ($amountdeposit as $tva => $amount) {
1799 if (empty($amount)) {
1804 'amount' =>
'FixAmount',
1805 'variable' =>
'VarAmount'
1807 $descline =
'(DEPOSIT)';
1809 if ($typeamount ==
'amount') {
1810 $descline .=
' ('.price($valuedeposit, 0, $langs, 0, - 1, - 1, (!empty(
$object->multicurrency_code) ?
$object->multicurrency_code :
$conf->currency)).
')';
1811 } elseif ($typeamount ==
'variable') {
1812 $descline .=
' ('.$valuedeposit.
'%)';
1815 $descline .=
' - '.$srcobject->ref;
1828 $i >= 0 ? $lines[$i]->info_bits : 0,
1834 $i >= 0 ? $lines[$i]->special_code : 0,
1847 (!empty(
$conf->global->MAIN_DEPOSIT_MULTI_TVA) ? 0 : 1)
1851 $diff =
$object->total_ttc - $amount_ttc_diff;
1855 $subprice_diff =
$object->lines[0]->subprice - $diff / (1 +
$object->lines[0]->tva_tx / 100);
1856 $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);
1865 $lines = $srcobject->lines;
1866 if (empty($lines) && method_exists($srcobject,
'fetch_lines')) {
1867 $srcobject->fetch_lines();
1868 $lines = $srcobject->lines;
1873 if (is_array($lines)) {
1874 foreach ($lines as $line) {
1876 $line->qty = (float)
price2num((
float) $line->qty * (float) $valuestandardinvoice / 100,
'MS');
1882 if (is_array($lines)) {
1883 foreach ($lines as $line) {
1885 $line->qty = (float)
price2num((
float) $line->qty * (float) $valuedeposit / 100,
'MS');
1890 $fk_parent_line = 0;
1891 $num = count($lines);
1893 for ($i = 0; $i < $num; $i++) {
1894 if (!in_array($lines[$i]->
id, $selectedLines)) {
1899 if ($srcobject->element ==
'shipping' &&
getDolGlobalString(
'SHIPMENT_GETS_ALL_ORDER_PRODUCTS') && $lines[$i]->qty == 0) {
1903 if (!isset(
$conf->global->CONTRACT_EXCLUDE_SERVICES_STATUS_FOR_INVOICE)) {
1904 $conf->global->CONTRACT_EXCLUDE_SERVICES_STATUS_FOR_INVOICE =
'5';
1906 if ($srcobject->element ==
'contrat' && in_array($lines[$i]->statut, explode(
',',
getDolGlobalString(
'CONTRACT_EXCLUDE_SERVICES_STATUS_FOR_INVOICE')))) {
1910 $label = (!empty($lines[$i]->label) ? $lines[$i]->label :
'');
1911 $desc = (!empty($lines[$i]->desc) ? $lines[$i]->desc :
'');
1913 if (
$object->situation_counter == 1) {
1914 $lines[$i]->situation_percent = 0;
1917 if ($lines[$i]->subprice < 0 && !
getDolGlobalString(
'INVOICE_KEEP_DISCOUNT_LINES_AS_IN_ORIGIN')) {
1920 $desc = $label ? $label : $langs->trans(
'Discount');
1924 $discount->fk_soc =
$object->socid;
1925 $discount->socid =
$object->socid;
1926 $discount->amount_ht = abs($lines[$i]->total_ht);
1927 $discount->amount_tva = abs($lines[$i]->total_tva);
1928 $discount->amount_ttc = abs($lines[$i]->total_ttc);
1929 $discount->total_ht = abs($lines[$i]->total_ht);
1930 $discount->total_tva = abs($lines[$i]->total_tva);
1931 $discount->total_ttc = abs($lines[$i]->total_ttc);
1932 $discount->tva_tx = $lines[$i]->tva_tx;
1933 $discount->fk_user = $user->id;
1934 $discount->description = $desc;
1935 $discount->multicurrency_subprice = abs($lines[$i]->multicurrency_subprice);
1936 $discount->multicurrency_amount_ht = abs($lines[$i]->multicurrency_total_ht);
1937 $discount->multicurrency_amount_tva = abs($lines[$i]->multicurrency_total_tva);
1938 $discount->multicurrency_amount_ttc = abs($lines[$i]->multicurrency_total_ttc);
1939 $discount->multicurrency_total_ht = abs($lines[$i]->multicurrency_total_ht);
1940 $discount->multicurrency_total_tva = abs($lines[$i]->multicurrency_total_tva);
1941 $discount->multicurrency_total_ttc = abs($lines[$i]->multicurrency_total_ttc);
1943 $discountid = $discount->create($user);
1944 if ($discountid > 0) {
1945 $result =
$object->insert_discount($discountid);
1957 $date_start =
false;
1958 if (isset($lines[$i]->date_debut_prevue)) {
1959 $date_start = $lines[$i]->date_debut_prevue;
1961 if (isset($lines[$i]->date_debut_reel)) {
1962 $date_start = $lines[$i]->date_debut_reel;
1964 if (isset($lines[$i]->date_start)) {
1965 $date_start = $lines[$i]->date_start;
1970 if (isset($lines[$i]->date_fin_prevue)) {
1971 $date_end = $lines[$i]->date_fin_prevue;
1973 if (isset($lines[$i]->date_fin_reel)) {
1974 $date_end = $lines[$i]->date_fin_reel;
1976 if (isset($lines[$i]->date_end)) {
1977 $date_end = $lines[$i]->date_end;
1981 if (($lines[$i]->product_type != 9 && empty($lines[$i]->fk_parent_line)) || $lines[$i]->product_type == 9) {
1982 $fk_parent_line = 0;
1985 $array_options = array();
1987 if (method_exists($lines[$i],
'fetch_optionals')) {
1988 $lines[$i]->fetch_optionals();
1989 $array_options = $lines[$i]->array_options;
1992 $tva_tx = $lines[$i]->tva_tx;
1993 if (!empty($lines[$i]->vat_src_code) && !preg_match(
'/\(/', (
string) $tva_tx)) {
1994 $tva_tx .=
' ('.$lines[$i]->vat_src_code.
')';
2004 $lines[$i]->subprice,
2009 $lines[$i]->fk_product,
2010 $lines[$i]->remise_percent,
2014 $lines[$i]->info_bits,
2015 isset($lines[$i]->fk_remise_except) ? $lines[$i]->fk_remise_except : null,
2020 $lines[$i]->special_code,
2024 isset($lines[$i]->fk_fournprice) ? $lines[$i]->fk_fournprice : null,
2028 $lines[$i]->situation_percent ?? 100,
2029 $lines[$i]->fk_prev_id ?? 0,
2030 $lines[$i]->fk_unit,
2037 foreach (
$object->lines as $line) {
2038 if ($line->id == $result) {
2039 $line->extraparams = $lines[$i]->extraparams;
2040 $line->setExtraParameters();
2052 if ($result > 0 && $lines[$i]->product_type == 9) {
2053 $fk_parent_line = $result;
2063 $object->update_price(1,
'auto', 0, $mysoc);
2065 $object->line_order(
true,
'DESC');
2093 $parameters = array(
'origin_type' =>
$object->origin_type,
'origin_id' =>
$object->origin_id,
'objFrom' => $srcobject);
2094 $reshook = $hookmanager->executeHooks(
'createFrom', $parameters,
$object, $action);
2107 for ($i = 1; $i <= $NBLINES; $i++) {
2113 $result =
$object->addline($product->description, $product->price, (
float)
price2num(
GETPOST(
'qty'.$i),
'MS'), $product->tva_tx, $product->localtax1_tx, $product->localtax2_tx,
GETPOSTINT(
'idprod'.$i), (
float)
price2num(
GETPOST(
'remise_percent'.$i),
'', 2), $startday, $endday, 0, 0, 0, $product->price_base_type, $product->price_ttc, $product->type, -1, 0,
'', 0, 0, 0, 0,
'', array(), 100, 0, $product->fk_unit, 0,
'', 1);
2117 $object->update_price(1,
'auto', 0, $mysoc);
2124 if (empty($dateinvoice)) {
2126 $mesg = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Date"));
2136 $mesg = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"InvoiceSituation"));
2146 if (!empty($origin) && !empty($originid)) {
2147 include_once DOL_DOCUMENT_ROOT.
'/core/lib/price.lib.php';
2150 $object->origin_type = $origin;
2151 $object->origin_id = $originid;
2155 $retained_warranty =
GETPOSTINT(
'retained_warranty');
2156 if (
price2num($retained_warranty) > 0) {
2160 if (
GETPOSTINT(
'retained_warranty_fk_cond_reglement') > 0) {
2161 $object->retained_warranty_fk_cond_reglement =
GETPOSTINT(
'retained_warranty_fk_cond_reglement');
2164 $retained_warranty_date_limit =
GETPOST(
'retained_warranty_date_limit');
2165 if (!empty($retained_warranty_date_limit) && $db->jdate($retained_warranty_date_limit)) {
2166 $object->retained_warranty_date_limit = $db->jdate($retained_warranty_date_limit);
2168 $object->retained_warranty_date_limit = !empty(
$object->retained_warranty_date_limit) ?
$object->retained_warranty_date_limit :
$object->calculate_date_lim_reglement(
$object->retained_warranty_fk_cond_reglement);
2171 foreach (
$object->lines as $i => &$line) {
2172 $line->fk_prev_id = $line->id;
2173 $line->fetch_optionals();
2175 $line->situation_percent = 0;
2177 $line->situation_percent = $line->get_prev_progress(
$object->id);
2181 $tabprice =
calcul_price_total($line->qty, $line->subprice, $line->remise_percent, $line->tva_tx, $line->localtax1_tx, $line->localtax2_tx, 0,
'HT', 0, $line->product_type, $mysoc, array(), $line->situation_percent);
2182 $line->total_ht = (float) $tabprice[0];
2183 $line->total_tva = (float) $tabprice[1];
2184 $line->total_ttc = (float) $tabprice[2];
2185 $line->total_localtax1 = (float) $tabprice[9];
2186 $line->total_localtax2 = (float) $tabprice[10];
2187 $line->multicurrency_total_ht = (float) $tabprice[16];
2188 $line->multicurrency_total_tva = (float) $tabprice[17];
2189 $line->multicurrency_total_ttc = (float) $tabprice[18];
2192 if ($line->fk_remise_except) {
2194 $result = $discount->fetch($line->fk_remise_except);
2197 if ($discount->fk_facture_line > 0) {
2198 $line->fk_remise_except = 0;
2207 $object->date_pointoftax = $date_pointoftax;
2208 $object->note_public = trim(
GETPOST(
'note_public',
'restricthtml'));
2224 $object->situation_counter += 1;
2230 $nextSituationInvoice =
new Facture($db);
2231 $nextSituationInvoice->fetch($id);
2234 $extrafields->fetch_name_optionals_label($nextSituationInvoice->table_element);
2235 $ret = $extrafields->setOptionalsFromPost(
null, $nextSituationInvoice);
2237 $nextSituationInvoice->insertExtraFields();
2241 $parameters = array(
'origin_type' =>
$object->origin_type,
'origin_id' =>
$object->origin_id);
2242 $reshook = $hookmanager->executeHooks(
'createFrom', $parameters, $nextSituationInvoice, $action);
2253 if ($id > 0 && !$error) {
2254 if (isModEnabled(
'category')) {
2255 $categories =
GETPOST(
'categories',
'array');
2256 if (method_exists(
$object,
'setCategories')) {
2257 $object->setCategories($categories);
2265 $outputlangs = $langs;
2268 $newlang =
GETPOST(
'lang_id',
'aZ09');
2271 if (empty(
$object->thirdparty)) {
2274 $newlang =
$object->thirdparty->default_lang;
2276 if (!empty($newlang)) {
2278 $outputlangs->setDefaultLang($newlang);
2279 $outputlangs->load(
'products');
2284 $result =
$object->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
2290 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
2295 $_GET[
"origin"] = $_POST[
"origin"];
2296 $_GET[
"originid"] = $_POST[
"originid"];
2299 } elseif ($action ==
'addline' &&
GETPOST(
'submitforalllines',
'aZ09') && (
GETPOST(
'alldate_start',
'alpha') ||
GETPOST(
'alldate_end',
'alpha')) && $usercancreate) {
2303 foreach (
$object->lines as $line) {
2304 if ($line->special_code == SUBTOTALS_SPECIAL_CODE) {
2307 if ($line->product_type == 1) {
2308 $result =
$object->updateline($line->id, $line->desc, $line->subprice, $line->qty, $line->remise_percent, $alldate_start, $alldate_end, $line->tva_tx, $line->localtax1_tx, $line->localtax2_tx,
'HT', $line->info_bits, $line->product_type, $line->fk_parent_line, 0, $line->fk_fournprice, $line->pa_ht, $line->label, $line->special_code, $line->array_options, $line->situation_percent, $line->fk_unit, $line->multicurrency_subprice);
2311 } elseif ($action ==
'addline' &&
GETPOST(
'submitforalllines',
'alpha') &&
GETPOST(
'vatforalllines',
'alpha') !==
'' && $usercancreate) {
2313 $vat_rate = (
GETPOST(
'vatforalllines') ?
GETPOST(
'vatforalllines') : 0);
2314 $vat_rate = str_replace(
'*',
'', $vat_rate);
2317 foreach (
$object->lines as $line) {
2318 if ($line->special_code == SUBTOTALS_SPECIAL_CODE) {
2321 $result =
$object->updateline($line->id, $line->desc, $line->subprice, $line->qty, $line->remise_percent, $line->date_start, $line->date_end, $vat_rate, $localtax1_rate, $localtax2_rate,
'HT', $line->info_bits, $line->product_type, $line->fk_parent_line, 0, $line->fk_fournprice, $line->pa_ht, $line->label, $line->special_code, $line->array_options, $line->situation_percent, $line->fk_unit, $line->multicurrency_subprice);
2323 } elseif ($action ==
'addline' &&
GETPOST(
'submitforalllines',
'alpha') &&
GETPOST(
'remiseforalllines',
'alpha') !==
'' && $usercancreate) {
2325 $remise_percent = (
GETPOST(
'remiseforalllines') ?
GETPOST(
'remiseforalllines') : 0);
2326 $remise_percent = str_replace(
'*',
'', $remise_percent);
2327 foreach (
$object->lines as $line) {
2328 if ($line->special_code == SUBTOTALS_SPECIAL_CODE) {
2331 $tvatx = $line->tva_tx;
2332 if (!empty($line->vat_src_code)) {
2333 $tvatx .=
' ('.$line->vat_src_code.
')';
2335 $result =
$object->updateline($line->id, $line->desc, $line->subprice, $line->qty, (
float) $remise_percent, $line->date_start, $line->date_end, $tvatx, $line->localtax1_tx, $line->localtax2_tx,
'HT', $line->info_bits, $line->product_type, $line->fk_parent_line, 0, $line->fk_fournprice, $line->pa_ht, $line->label, $line->special_code, $line->array_options, $line->situation_percent, $line->fk_unit, $line->multicurrency_subprice);
2337 } elseif ($action ==
'confirm_addtitleline' && $usercancreate) {
2340 $langs->load(
'subtotals');
2342 $desc =
GETPOST(
'subtotallinedesc',
'alphanohtml');
2343 $depth =
GETPOSTINT(
'subtotallinelevel') ?? 1;
2345 $subtotal_options = array();
2347 foreach (Facture::$TITLE_OPTIONS as $option) {
2348 $value =
GETPOST($option,
'alphanohtml');
2350 $subtotal_options[$option] = $value ==
'on' ? 1 : $value;
2355 $result =
$object->addSubtotalLine($langs, $desc, (
int) $depth, $subtotal_options);
2366 $outputlangs = $langs;
2367 $newlang =
GETPOST(
'lang_id',
'alpha');
2369 $newlang =
$object->thirdparty->default_lang;
2371 if (!empty($newlang)) {
2373 $outputlangs->setDefaultLang($newlang);
2376 $object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
2381 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
2383 } elseif ($action ==
'confirm_addsubtotalline' && $usercancreate) {
2386 $langs->load(
'subtotals');
2388 $choosen_line =
GETPOST(
'subtotaltitleline',
'alphanohtml');
2389 foreach (
$object->lines as $line) {
2390 if ($line->desc == $choosen_line && $line->special_code == SUBTOTALS_SPECIAL_CODE) {
2391 $desc = $line->desc;
2392 $depth = -$line->qty;
2396 $subtotal_options = array();
2398 foreach (Facture::$SUBTOTAL_OPTIONS as $option) {
2399 $value =
GETPOST($option,
'alphanohtml');
2401 $subtotal_options[$option] = $value ==
'on' ? 1 : $value;
2406 if (isset($desc) && isset($depth)) {
2407 $result =
$object->addSubtotalLine($langs, $desc, (
int) $depth, $subtotal_options);
2409 $object->errors[] = $langs->trans(
"CorrespondingTitleNotFound");
2412 if (isset($result) && $result >= 0) {
2418 $outputlangs = $langs;
2419 $newlang =
GETPOST(
'lang_id',
'alpha');
2421 $newlang =
$object->thirdparty->default_lang;
2423 if (!empty($newlang)) {
2425 $outputlangs->setDefaultLang($newlang);
2428 $object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
2433 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
2435 } elseif ($action ==
'addline' &&
GETPOST(
'updateallvatlinesblock',
'alpha') &&
GETPOST(
'vatforblocklines',
'alpha') !==
'' && $usercancreate) {
2436 $tx_tva =
GETPOST(
'vatforblocklines') ?
GETPOST(
'vatforblocklines') : 0;
2437 $object->updateSubtotalLineBlockLines($langs,
$object->getRangOfLine($lineid),
'tva', $tx_tva);
2438 } elseif ($action ==
'addline' &&
GETPOST(
'updatealldiscountlinesblock',
'alpha') &&
GETPOST(
'discountforblocklines',
'alpha') !==
'' && $usercancreate) {
2439 $discount =
GETPOST(
'discountforblocklines') ?
GETPOST(
'discountforblocklines') : 0;
2440 $object->updateSubtotalLineBlockLines($langs,
$object->getRangOfLine($lineid),
'discount', $discount);
2441 } elseif ($action ==
'addline' && !
GETPOST(
'submitforalllines',
'alpha') && !
GETPOST(
'submitforallmargins',
'alpha') && !
GETPOST(
'submitforallmark',
'alpha') && $usercancreate) {
2442 $langs->load(
'errors');
2447 $line_desc = (GETPOSTISSET(
'dp_desc') ?
GETPOST(
'dp_desc',
'restricthtml') :
'');
2450 $price_ht_devise =
'';
2452 $price_ttc_devise =
'';
2455 $price_min_ttc =
'';
2457 if (
GETPOST(
'price_ht') !==
'') {
2460 if (
GETPOST(
'multicurrency_price_ht') !==
'') {
2463 if (
GETPOST(
'price_ttc') !==
'') {
2466 if (
GETPOST(
'multicurrency_price_ttc') !==
'') {
2467 $price_ttc_devise =
price2num(
GETPOST(
'multicurrency_price_ttc'),
'CU', 2);
2470 $prod_entry_mode =
GETPOST(
'prod_entry_mode',
'aZ09');
2471 if ($prod_entry_mode ==
'free') {
2477 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"ProductOrService")),
null,
'errors');
2482 $tva_tx =
GETPOST(
'tva_tx',
'alpha');
2485 $remise_percent = (GETPOSTISSET(
'remise_percent'.$predef) ?
price2num(
GETPOST(
'remise_percent'.$predef,
'alpha'),
'', 2) : 0);
2486 if (empty($remise_percent)) {
2487 $remise_percent = 0;
2491 $extralabelsline = $extrafields->fetch_name_optionals_label(
$object->table_element_line);
2492 $array_options = $extrafields->getOptionalsFromPost(
$object->table_element_line, $predef);
2494 if (is_array($extralabelsline)) {
2496 foreach ($extralabelsline as $key => $value) {
2497 unset($_POST[
"options_".$key.$predef]);
2501 if ((empty($idprod) || $idprod < 0) && ($price_ht < 0) && ($qty < 0)) {
2502 setEventMessages($langs->trans(
'ErrorBothFieldCantBeNegative', $langs->transnoentitiesnoconv(
'UnitPriceHT'), $langs->transnoentitiesnoconv(
'Qty')),
null,
'errors');
2505 if (!$prod_entry_mode) {
2507 setEventMessages($langs->trans(
'ErrorChooseBetweenFreeEntryOrPredefinedProduct'),
null,
'errors');
2511 if ($prod_entry_mode ==
'free' && (empty($idprod) || $idprod < 0) &&
GETPOST(
'type') < 0) {
2512 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'Type')),
null,
'errors');
2517 if ($prod_entry_mode ==
'free' && (empty($idprod) || $idprod < 0)
2518 && (((
float) $price_ht < 0 && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES')) || $price_ht ===
'')
2519 && (((
float) $price_ht_devise < 0 && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES')) || $price_ht_devise ===
'')
2520 && ((
float) $price_ttc < 0 && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES') || $price_ttc ===
'')
2521 && ((
float) $price_ttc_devise < 0 && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES') || $price_ttc_devise ===
'')
2522 &&
$object->type != $object::TYPE_CREDIT_NOTE) {
2523 if (((
float) $price_ht < 0 || (
float) $price_ttc < 0) && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES')) {
2524 $langs->load(
"errors");
2525 if (
$object->type == $object::TYPE_DEPOSIT) {
2527 setEventMessages($langs->trans(
"ErrorLinesCantBeNegativeOnDeposits"),
null,
'errors');
2529 setEventMessages($langs->trans(
"ErrorFieldCantBeNegativeOnInvoice", $langs->transnoentitiesnoconv(
"UnitPriceHT"), $langs->transnoentitiesnoconv(
"CustomerAbsoluteDiscountShort")),
null,
'errors');
2534 if ($prod_entry_mode ==
'free' && (empty($idprod) || $idprod < 0) &&
GETPOST(
'price_ht') ===
'' &&
GETPOST(
'price_ttc') ===
'' && $price_ht_devise ===
'') {
2535 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'UnitPrice')),
null,
'errors');
2539 if ($prod_entry_mode ==
'free' && (empty($idprod) || $idprod < 0) && empty($line_desc)) {
2540 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'Description')),
null,
'errors');
2544 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'Qty')),
null,
'errors');
2548 $langs->load(
"errors");
2549 setEventMessages($langs->trans(
'ErrorQtyForCustomerInvoiceCantBeNegative'),
null,
'errors');
2553 if (!$error && isModEnabled(
'variants') && $prod_entry_mode !=
'free') {
2554 if ($combinations =
GETPOST(
'combinations',
'array')) {
2558 if ($res = $prodcomb->fetchByProductCombination2ValuePairs($idprod, $combinations)) {
2559 $idprod = $res->fk_product_child;
2561 setEventMessages($langs->trans(
'ErrorProductCombinationNotFound'),
null,
'errors');
2567 $price_base_type =
null;
2568 if (!$error && ($qty >= 0) && (!empty($line_desc) || (!empty($idprod) && $idprod > 0))) {
2574 $ret =
$object->fetch_thirdparty();
2579 $price_base_type = (
GETPOST(
'price_base_type',
'alpha') ?
GETPOST(
'price_base_type',
'alpha') :
'HT');
2590 if (!empty($idprod) && $idprod > 0) {
2592 $prod->fetch($idprod);
2594 $label = ((
GETPOST(
'product_label') &&
GETPOST(
'product_label') != $prod->label) ?
GETPOST(
'product_label') :
'');
2599 $datapriceofproduct = $prod->getSellPrice($mysoc,
$object->thirdparty, $pqp);
2601 $pu_ht = $datapriceofproduct[
'pu_ht'];
2602 $pu_ttc = $datapriceofproduct[
'pu_ttc'];
2603 $price_min = $datapriceofproduct[
'price_min'];
2604 $price_min_ttc = (isset($datapriceofproduct[
'price_min_ttc'])) ? $datapriceofproduct[
'price_min_ttc'] : null;
2605 $price_base_type = empty($datapriceofproduct[
'price_base_type']) ?
'HT' : $datapriceofproduct[
'price_base_type'];
2609 $tmpvat = (float)
price2num(preg_replace(
'/\s*\(.*\)/',
'', $tva_tx));
2610 $tmpprodvat =
price2num(preg_replace(
'/\s*\(.*\)/',
'', (
string) $prod->tva_tx));
2614 if (!empty($price_ht) || $price_ht ===
'0') {
2616 $pu_ttc =
price2num((
float) $pu_ht * (1 + ($tmpvat / 100)),
'MU');
2617 } elseif (!empty($price_ht_devise) || $price_ht_devise ===
'0') {
2618 $pu_ht_devise =
price2num($price_ht_devise,
'MU');
2621 } elseif (!empty($price_ttc) || $price_ttc ===
'0') {
2623 $pu_ht =
price2num((
float) $pu_ttc / (1 + ($tmpvat / 100)),
'MU');
2624 } elseif ($tmpvat != $tmpprodvat) {
2626 if ($price_base_type !=
'HT') {
2627 $pu_ht =
price2num($pu_ttc / (1 + ($tmpvat / 100)),
'MU');
2629 $pu_ttc =
price2num($pu_ht * (1 + ($tmpvat / 100)),
'MU');
2633 $outputlangs = $langs;
2639 if (
GETPOST(
'lang_id',
'aZ09')) {
2640 $newlang =
GETPOST(
'lang_id',
'aZ09');
2642 if (empty($newlang)) {
2643 $newlang =
$object->thirdparty->default_lang;
2645 if (!empty($newlang)) {
2647 $outputlangs->setDefaultLang($newlang);
2648 $outputlangs->load(
'products');
2651 $desc = (!empty($prod->multilangs [$outputlangs->defaultlang] [
"description"])) ? $prod->multilangs [$outputlangs->defaultlang] [
"description"] : $prod->
description;
2653 $desc = $prod->description;
2665 if (!
getDolGlobalString(
'MAIN_PRODUCT_DISABLE_CUSTOMCOUNTRYCODE') && (!empty($prod->customcode) || !empty($prod->country_code))) {
2669 if (!empty($prod->customcode)) {
2670 $tmptxt .= $outputlangs->transnoentitiesnoconv(
"CustomsCode").
': '.$prod->customcode;
2672 if (!empty($prod->customcode) && !empty($prod->country_code)) {
2675 if (!empty($prod->country_code)) {
2676 $tmptxt .= $outputlangs->transnoentitiesnoconv(
"CountryOrigin").
': '.
getCountry($prod->country_code,
'', $db, $outputlangs, 0);
2679 if (!empty($prod->customcode)) {
2680 $tmptxt .= $langs->transnoentitiesnoconv(
"CustomsCode").
': '.$prod->customcode;
2682 if (!empty($prod->customcode) && !empty($prod->country_code)) {
2685 if (!empty($prod->country_code)) {
2686 $tmptxt .= $langs->transnoentitiesnoconv(
"CountryOrigin").
': '.
getCountry($prod->country_code,
'', $db, $langs, 0);
2693 $type = $prod->type;
2694 $fk_unit = $prod->fk_unit;
2696 if (!empty($price_ht)) {
2701 if (!empty($price_ttc)) {
2706 $tva_npr = (preg_match(
'/\*/', $tva_tx) ? 1 : 0);
2707 $tva_tx = str_replace(
'*',
'', $tva_tx);
2708 if (empty($tva_tx)) {
2711 $label = (
GETPOST(
'product_label') ?
GETPOST(
'product_label') :
'');
2714 $fk_unit =
GETPOST(
'units',
'alpha');
2716 if ($pu_ttc && !$pu_ht) {
2717 $price_base_type =
'TTC';
2731 $pu_ht_devise =
price2num($price_ht_devise,
'', 2);
2732 $pu_ttc_devise =
price2num($price_ttc_devise,
'', 2);
2735 $pu_equivalent = $pu_ht;
2736 $pu_equivalent_ttc = $pu_ttc;
2738 $currency_tx =
$object->multicurrency_tx;
2742 if ($pu_ht ==
'' && $pu_ht_devise !=
'' && $currency_tx !=
'') {
2743 $pu_equivalent = (float) $pu_ht_devise * $currency_tx;
2745 if ($pu_ttc ==
'' && $pu_ttc_devise !=
'' && $currency_tx !=
'') {
2746 $pu_equivalent_ttc = (float) $pu_ttc_devise * $currency_tx;
2761 $fournprice = (int) (
GETPOST(
'fournprice'.$predef) ?
GETPOST(
'fournprice'.$predef) :
'');
2766 $price2num_remise_percent =
price2num($remise_percent);
2767 $price2num_price_min =
price2num($price_min);
2768 $price2num_price_min_ttc =
price2num($price_min_ttc);
2769 if (empty($price2num_pu_ht)) {
2770 $price2num_pu_ht = 0;
2772 if (empty($price2num_remise_percent)) {
2773 $price2num_remise_percent = 0;
2775 if (empty($price2num_price_min)) {
2776 $price2num_price_min = 0;
2778 if (empty($price2num_price_min_ttc)) {
2779 $price2num_price_min_ttc = 0;
2784 if ($pu_equivalent && $price_min && (((
float)
price2num($pu_equivalent) * (1 - $remise_percent / 100)) < (
float)
price2num($price_min)) && $price_base_type ==
'HT') {
2785 $mesg = $langs->trans(
"CantBeLessThanMinPrice",
price(
price2num($price_min,
'MU'), 0, $langs, 0, 0, -1,
$conf->currency));
2788 } elseif ($pu_equivalent_ttc && $price_min_ttc && (((
float)
price2num($pu_equivalent_ttc) * (1 - $remise_percent / 100)) < (
float)
price2num($price_min_ttc)) && $price_base_type ==
'TTC') {
2789 $mesg = $langs->trans(
"CantBeLessThanMinPriceInclTax",
price(
price2num($price_min_ttc,
'MU'), 0, $langs, 0, 0, -1,
$conf->currency));
2796 '@phan-var-force CommonObjectLine[] $lines';
2798 if (isModEnabled(
'productbatch') && !empty($lines[$i]->detail_batch) && is_array($lines[$i]->detail_batch) &&
getDolGlobalString(
'INVOICE_INCUDE_DETAILS_OF_LOTS_SERIALS')) {
2799 $langs->load(
'productbatch');
2800 foreach ($lines[$i]->detail_batch as $batchline) {
2801 $desc .=
' '.$langs->trans(
'Batch').
' '.$batchline->batch.
' '.$langs->trans(
'printQty', $batchline->qty).
' ';
2805 $situation_percent = GETPOSTISSET(
'progress') ?
GETPOSTINT(
'progress') : 100;
2808 $result =
$object->addline($desc, $pu_ht, (
float) $qty, $tva_tx, $localtax1_tx, $localtax2_tx, $idprod, $remise_percent, $date_start, $date_end, 0, $info_bits, 0, $price_base_type, $pu_ttc, $type, min($rank, count(
$object->lines) + 1), $special_code,
'', 0,
GETPOSTINT(
'fk_parent_line'), (
int) $fournprice, $buyingprice, $label, $array_options, $situation_percent, 0, $fk_unit, (
float) $pu_ht_devise);
2813 $outputlangs = $langs;
2816 $newlang =
GETPOST(
'lang_id',
'aZ09');
2819 $newlang =
$object->thirdparty->default_lang;
2821 if (!empty($newlang)) {
2823 $outputlangs->setDefaultLang($newlang);
2824 $outputlangs->load(
'products');
2829 $result =
$object->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
2835 unset($_POST[
'prod_entry_mode']);
2836 unset($_POST[
'qty']);
2837 unset($_POST[
'type']);
2838 unset($_POST[
'remise_percent']);
2839 unset($_POST[
'price_ht']);
2840 unset($_POST[
'multicurrency_price_ht']);
2841 unset($_POST[
'price_ttc']);
2842 unset($_POST[
'tva_tx']);
2843 unset($_POST[
'product_ref']);
2844 unset($_POST[
'product_label']);
2845 unset($_POST[
'product_desc']);
2846 unset($_POST[
'fournprice']);
2847 unset($_POST[
'buying_price']);
2848 unset($_POST[
'np_marginRate']);
2849 unset($_POST[
'np_markRate']);
2850 unset($_POST[
'dp_desc']);
2851 unset($_POST[
'idprod']);
2852 unset($_POST[
'units']);
2853 unset($_POST[
'date_starthour']);
2854 unset($_POST[
'date_startmin']);
2855 unset($_POST[
'date_startsec']);
2856 unset($_POST[
'date_startday']);
2857 unset($_POST[
'date_startmonth']);
2858 unset($_POST[
'date_startyear']);
2859 unset($_POST[
'date_endhour']);
2860 unset($_POST[
'date_endmin']);
2861 unset($_POST[
'date_endsec']);
2862 unset($_POST[
'date_endday']);
2863 unset($_POST[
'date_endmonth']);
2864 unset($_POST[
'date_endyear']);
2865 unset($_POST[
'situations']);
2866 unset($_POST[
'progress']);
2874 } elseif ($action ==
'addline' && $usercancreate && (
2875 (
GETPOST(
'submitforallmargins',
'alpha') &&
GETPOST(
'marginforalllines',
'alpha') !==
'') ||
2876 (
GETPOST(
'submitforallmark',
'alpha') &&
GETPOST(
'markforalllines',
'alpha') !==
''))) {
2878 $margin_rate = GETPOSTISSET(
'marginforalllines') ?
GETPOST(
'marginforalllines',
'int') :
'';
2879 $mark_rate = GETPOSTISSET(
'markforalllines') ?
GETPOST(
'markforalllines',
'int') :
'';
2880 foreach (
$object->lines as &$line)
if ($line->subprice > 0) {
2881 if ($line->special_code == SUBTOTALS_SPECIAL_CODE) {
2884 $subprice_multicurrency = $line->subprice;
2885 if (is_numeric($margin_rate) && $margin_rate > 0) {
2886 $line->subprice = floatval(
price2num(floatval($line->pa_ht) * (1 + floatval($margin_rate) / 100),
'MU'));
2887 } elseif (is_numeric($mark_rate) && $mark_rate > 0) {
2888 $line->subprice = floatval($line->pa_ht / (1 - (floatval($mark_rate) / 100)));
2890 $line->subprice = floatval($line->pa_ht);
2894 $res = $prod->fetch($line->fk_product);
2896 if ($prod->price_min > $line->subprice) {
2897 $price_subprice =
price($line->subprice, 0, $outlangs, 1, -1, -1,
'auto');
2898 $price_price_min =
price($prod->price_min, 0, $outlangs, 1, -1, -1,
'auto');
2899 setEventMessages($prod->ref .
' - ' . $prod->label .
' (' . $price_subprice .
' < ' . $price_price_min .
' ' . strtolower($langs->trans(
"MinPrice")) .
')' .
"\n",
null,
'warnings');
2907 $multicurrency_subprice = (float) $line->subprice * $line->multicurrency_subprice / $subprice_multicurrency;
2909 $result =
$object->updateline($line->id, $line->desc, $line->subprice, $line->qty, $line->remise_percent, $line->date_start, $line->date_end, $line->tva_tx, $line->localtax1_tx, $line->localtax2_tx,
'HT', $line->info_bits, $line->product_type, $line->fk_parent_line, 0, $line->fk_fournprice, $line->pa_ht, $line->product_ref, $line->special_code, $line->array_options, $line->situation_percent, $line->fk_unit, $multicurrency_subprice);
2912 if (is_numeric($margin_rate) && empty($mark_rate)) {
2913 $line->marge_tx = $margin_rate;
2914 } elseif (is_numeric($mark_rate) && empty($margin_rate)) {
2915 $line->marque_tx = $mark_rate;
2917 $line->total_ht = $line->qty * (float) $line->subprice;
2918 $line->total_tva = $line->tva_tx * $line->qty * (float) $line->subprice;
2919 $line->total_ttc = (1 + $line->tva_tx) * $line->qty * (
float) $line->subprice;
2921 $line->multicurrency_total_ht = $line->qty * (float) $subprice_multicurrency * $line->multicurrency_subprice / $line->subprice;
2922 $line->multicurrency_total_tva = $line->tva_tx * $line->qty * (float) $subprice_multicurrency * $line->multicurrency_subprice / $line->subprice;
2923 $line->multicurrency_total_ttc = (1 + $line->tva_tx) * $line->qty * (
float) $subprice_multicurrency * $line->multicurrency_subprice / $line->subprice;
2925 $line->multicurrency_subprice = $multicurrency_subprice;
2930 } elseif ($action ==
'updatetitleline' && GETPOSTISSET(
"save") && $usercancreate && !
GETPOST(
'cancel',
'alpha')) {
2933 $langs->load(
'subtotals');
2935 $desc =
GETPOST(
'line_desc',
'alphanohtml') ?? $langs->trans(
"Title");
2938 $subtotal_options = array();
2940 foreach (Facture::$TITLE_OPTIONS as $option) {
2941 $value =
GETPOST($option,
'alphanohtml');
2943 $subtotal_options[$option] = $value ==
'on' ? 1 : $value;
2948 $result =
$object->updateSubtotalLine($langs,
GETPOSTINT(
'lineid'), $desc, $depth, $subtotal_options);
2959 $outputlangs = $langs;
2960 $newlang =
GETPOST(
'lang_id',
'alpha');
2962 $newlang =
$object->thirdparty->default_lang;
2964 if (!empty($newlang)) {
2966 $outputlangs->setDefaultLang($newlang);
2969 $object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
2974 } elseif ($action ==
'updatesubtotalline' && GETPOSTISSET(
"save") && $usercancreate && !
GETPOST(
'cancel',
'alpha')) {
2977 $langs->load(
'subtotals');
2979 $desc =
GETPOST(
'line_desc',
'alphanohtml');
2982 $subtotal_options = array();
2984 foreach (Facture::$SUBTOTAL_OPTIONS as $option) {
2985 $value =
GETPOST($option,
'alphanohtml');
2987 $subtotal_options[$option] = $value ==
'on' ? 1 : $value;
2992 $result =
$object->updateSubtotalLine($langs,
GETPOSTINT(
'lineid'), $desc, $depth, $subtotal_options);
3000 $outputlangs = $langs;
3001 $newlang =
GETPOST(
'lang_id',
'alpha');
3003 $newlang =
$object->thirdparty->default_lang;
3005 if (!empty($newlang)) {
3007 $outputlangs->setDefaultLang($newlang);
3010 $object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
3015 } elseif ($action ==
'updateline' && $usercancreate && !
GETPOST(
'cancel',
'alpha')) {
3016 if (!
$object->fetch($id) > 0) {
3039 if (preg_match(
'/\*/', $vat_rate)) {
3044 $vat_rate = str_replace(
'*',
'', $vat_rate);
3049 $fournprice = (int) (
GETPOST(
'fournprice') ?
GETPOST(
'fournprice') :
'');
3053 $pu_equivalent = $pu_ht;
3054 $pu_equivalent_ttc = $pu_ttc;
3056 $currency_tx =
$object->multicurrency_tx;
3060 if ($pu_ht ==
'' && $pu_ht_devise !=
'' && $currency_tx !=
'') {
3061 $pu_equivalent = (float) $pu_ht_devise * (
float) $currency_tx;
3063 if ($pu_ttc ==
'' && $pu_ttc_devise !=
'' && $currency_tx !=
'') {
3064 $pu_equivalent_ttc = (float) $pu_ttc_devise * (
float) $currency_tx;
3079 $extralabelsline = $extrafields->fetch_name_optionals_label(
$object->table_element_line);
3080 $array_options = $extrafields->getOptionalsFromPost(
$object->table_element_line);
3082 if (is_array($extralabelsline)) {
3084 foreach ($extralabelsline as $key => $value) {
3085 unset($_POST[
"options_".$key]);
3091 if ($special_code == 3) {
3097 $percent = $line->get_prev_progress(
$object->id);
3102 if ($progress >= 0) {
3103 $mesg = $langs->trans(
"CantBeNullOrPositive");
3107 } elseif ($progress < $line->situation_percent) {
3108 $mesg = $langs->trans(
"CantBeLessThanMinPercent");
3112 } elseif ($progress < $percent) {
3113 $mesg =
'<div class="warning">'.$langs->trans(
"CantBeLessThanMinPercent").
'</div>';
3122 $price_base_type =
'HT';
3124 if (empty($pu) && !empty($pu_ttc)) {
3126 $price_base_type =
'TTC';
3131 if (!empty($productid)) {
3133 $product->fetch($productid);
3135 $type = $product->type;
3137 $price_min = $product->price_min;
3139 $price_min = $product->multiprices_min[
$object->thirdparty->price_level];
3141 $price_min_ttc = $product->price_min_ttc;
3143 $price_min_ttc = $product->multiprices_min_ttc[
$object->thirdparty->price_level];
3150 if ($pu_equivalent && $price_min && (((
float)
price2num($pu_equivalent) * (1 - (
float) $remise_percent / 100)) < (float)
price2num($price_min)) && $price_base_type ==
'HT') {
3151 $mesg = $langs->trans(
"CantBeLessThanMinPrice",
price(
price2num($price_min,
'MU'), 0, $langs, 0, 0, -1,
$conf->currency));
3154 $action =
'editline';
3155 } elseif ($pu_equivalent_ttc && $price_min_ttc && (((
float)
price2num($pu_equivalent_ttc) * (1 - (
float) $remise_percent / 100)) < (
float)
price2num($price_min_ttc)) && $price_base_type ==
'TTC') {
3156 $mesg = $langs->trans(
"CantBeLessThanMinPriceInclTax",
price(
price2num($price_min_ttc,
'MU'), 0, $langs, 0, 0, -1,
$conf->currency));
3159 $action =
'editline';
3164 $label = (
GETPOST(
'product_label') ?
GETPOST(
'product_label') :
'');
3168 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Type")),
null,
'errors');
3173 $langs->load(
"errors");
3174 setEventMessages($langs->trans(
'ErrorQtyForCustomerInvoiceCantBeNegative'),
null,
'errors');
3178 if (($pu_ht < 0 || $pu_ttc < 0) && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES')) {
3179 $langs->load(
"errors");
3180 if (
$object->type == $object::TYPE_DEPOSIT) {
3182 setEventMessages($langs->trans(
"ErrorLinesCantBeNegativeOnDeposits"),
null,
'errors');
3184 setEventMessages($langs->trans(
"ErrorFieldCantBeNegativeOnInvoice", $langs->transnoentitiesnoconv(
"UnitPriceHT"), $langs->transnoentitiesnoconv(
"CustomerAbsoluteDiscountShort")),
null,
'errors');
3188 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"UnitPriceHT")),
null,
'errors');
3195 $previousprogress = $line->getAllPrevProgress($line->fk_facture);
3198 if ($fullprogress < $previousprogress) {
3200 setEventMessages($langs->trans(
'CantBeLessThanMinPercent'),
null,
'errors');
3204 if ($fullprogress > 100) {
3205 $fullprogress = 100;
3207 $addprogress = $fullprogress - $previousprogress;
3214 if (empty($usercancreatemargin)) {
3215 foreach (
$object->lines as &$line) {
3217 $fournprice = $line->fk_fournprice;
3218 $buyingprice = $line->pa_ht;
3224 $result =
$object->updateline(
3229 (
float) $remise_percent,
3247 (
float) $pu_ht_devise
3253 $outputlangs = $langs;
3256 $newlang =
GETPOST(
'lang_id',
'aZ09');
3259 $newlang =
$object->thirdparty->default_lang;
3261 if (!empty($newlang)) {
3263 $outputlangs->setDefaultLang($newlang);
3264 $outputlangs->load(
'products');
3268 $object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
3271 unset($_POST[
'qty']);
3272 unset($_POST[
'type']);
3273 unset($_POST[
'productid']);
3274 unset($_POST[
'remise_percent']);
3275 unset($_POST[
'price_ht']);
3276 unset($_POST[
'multicurrency_price_ht']);
3277 unset($_POST[
'price_ttc']);
3278 unset($_POST[
'tva_tx']);
3279 unset($_POST[
'product_ref']);
3280 unset($_POST[
'product_label']);
3281 unset($_POST[
'product_desc']);
3282 unset($_POST[
'fournprice']);
3283 unset($_POST[
'buying_price']);
3284 unset($_POST[
'np_marginRate']);
3285 unset($_POST[
'np_markRate']);
3286 unset($_POST[
'dp_desc']);
3287 unset($_POST[
'idprod']);
3288 unset($_POST[
'units']);
3289 unset($_POST[
'date_starthour']);
3290 unset($_POST[
'date_startmin']);
3291 unset($_POST[
'date_startsec']);
3292 unset($_POST[
'date_startday']);
3293 unset($_POST[
'date_startmonth']);
3294 unset($_POST[
'date_startyear']);
3295 unset($_POST[
'date_endhour']);
3296 unset($_POST[
'date_endmin']);
3297 unset($_POST[
'date_endsec']);
3298 unset($_POST[
'date_endday']);
3299 unset($_POST[
'date_endmonth']);
3300 unset($_POST[
'date_endyear']);
3301 unset($_POST[
'situations']);
3302 unset($_POST[
'progress']);
3307 } elseif ($action ==
'updatealllines' && $usercancreate &&
GETPOST(
'all_percent') == $langs->trans(
'Modify')) {
3308 if (!
$object->fetch($id) > 0) {
3311 if (
GETPOST(
'all_progress') !=
"") {
3313 foreach (
$object->lines as $line) {
3315 $percent = $line->getAllPrevProgress(
$object->id);
3317 $percent = $line->get_prev_progress(
$object->id);
3319 if ((
float) $all_progress < (
float) $percent) {
3320 $mesg = $langs->trans(
"Line").
' '.$line->rang.
' : '.$langs->trans(
"CantBeLessThanMinPercent");
3329 } elseif ($action ==
'updateline' && $usercancreate && !$cancel) {
3330 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
3332 } elseif ($action ==
'confirm_situationout' && $confirm ==
'yes' && $usercancreate) {
3334 $object->fetch($id,
'',
'', 0,
true);
3337 &&
$object->isSituationInvoice()
3340 &&
$object->is_last_in_cycle()
3341 && $usercanunvalidate
3344 $newCycle =
$object->newCycle();
3345 if ($newCycle > 1) {
3347 $lastCycle =
$object->situation_cycle_ref;
3348 $lastSituationCounter =
$object->situation_counter;
3349 $linkedCreditNotesList = array();
3351 if (count(
$object->tab_next_situation_invoice) > 0) {
3352 foreach (
$object->tab_next_situation_invoice as $next_invoice) {
3354 && $next_invoice->situation_counter ==
$object->situation_counter
3355 && $next_invoice->fk_facture_source ==
$object->id
3357 $linkedCreditNotesList[] = $next_invoice->id;
3362 $object->situation_cycle_ref = $newCycle;
3363 $object->situation_counter = 1;
3365 if (
$object->update($user) > 0) {
3367 if (count($linkedCreditNotesList) > 0) {
3369 $sql =
'UPDATE '.MAIN_DB_PREFIX.
'facture';
3370 $sql .=
' SET situation_cycle_ref = '.((int) $newCycle);
3371 $sql .=
' , situation_final=0';
3372 $sql .=
' , situation_counter='.((int)
$object->situation_counter);
3373 $sql .=
' WHERE rowid IN ('.$db->sanitize(implode(
',', $linkedCreditNotesList)).
')';
3375 $resql = $db->query($sql);
3381 foreach (
$object->lines as $line) {
3383 if ($line->product_type == 9) {
3388 if (!empty(
$object->tab_previous_situation_invoice)) {
3390 $lineIndex = count(
$object->tab_previous_situation_invoice) - 1;
3391 $searchPreviousInvoice =
true;
3392 while ($searchPreviousInvoice) {
3393 if (
$object->tab_previous_situation_invoice[$lineIndex]->isSituationInvoice() || $lineIndex < 1) {
3394 $searchPreviousInvoice =
false;
3402 $maxPrevSituationPercent = 0;
3403 foreach (
$object->tab_previous_situation_invoice[$lineIndex]->lines as $prevLine) {
3404 if ($prevLine->id == $line->fk_prev_id) {
3405 $maxPrevSituationPercent = max($maxPrevSituationPercent, $prevLine->situation_percent);
3410 $line->situation_percent -= $maxPrevSituationPercent;
3412 if ($line->update() < 0) {
3421 header(
"Location: ".$_SERVER[
'PHP_SELF'].
"?id=".$id);
3423 setEventMessages($langs->trans(
'ErrorOutingSituationInvoiceCreditNote'), array(),
'errors');
3426 setEventMessages($langs->trans(
'ErrorOutingSituationInvoiceOnUpdate'), array(),
'errors');
3429 setEventMessages($langs->trans(
'ErrorFindNextSituationInvoice'), array(),
'errors');
3435 $fromElement =
GETPOST(
'fromelement');
3436 $fromElementid =
GETPOST(
'fromelementid');
3437 $importLines =
GETPOST(
'line_checkbox');
3439 if (!empty($importLines) && is_array($importLines) && !empty($fromElement) && ctype_alpha($fromElement) && !empty($fromElementid)) {
3440 $lineClassName =
'';
3441 if ($fromElement ==
'commande') {
3443 $lineClassName =
'OrderLine';
3444 } elseif ($fromElement ==
'propal') {
3445 dol_include_once(
'/comm/'.$fromElement.
'/class/'.$fromElement.
'.class.php');
3446 $lineClassName =
'PropaleLigne';
3448 $nextRang = count(
$object->lines) + 1;
3451 foreach ($importLines as $lineId) {
3452 if ($lineClassName ===
'') {
3456 dol_syslog(
'compta/facture/card - No lineClassName - skip import', LOG_ERR);
3463 $lineId = intval($lineId);
3464 $originLine =
new $lineClassName($db);
3465 if (intval($fromElementid) > 0 && $originLine->fetch($lineId) > 0) {
3466 $originLine->fetch_optionals();
3467 $desc = $originLine->desc;
3468 $pu_ht = $originLine->subprice;
3469 $qty = $originLine->qty;
3470 $txtva = $originLine->tva_tx;
3471 $txlocaltax1 = $originLine->localtax1_tx;
3472 $txlocaltax2 = $originLine->localtax2_tx;
3473 $fk_product = $originLine->fk_product;
3474 $remise_percent = $originLine->remise_percent;
3475 $date_start = $originLine->date_start;
3476 $date_end = $originLine->date_end;
3477 $fk_code_ventilation = 0;
3478 $info_bits = $originLine->info_bits;
3479 $fk_remise_except = $originLine->fk_remise_except;
3480 $price_base_type =
'HT';
3482 $type = $originLine->product_type;
3483 $rang = $nextRang++;
3484 $special_code = $originLine->special_code;
3485 $origin = $originLine->element;
3486 $origin_id = $originLine->id;
3487 $fk_parent_line = 0;
3488 $fk_fournprice = $originLine->fk_fournprice;
3489 $pa_ht = $originLine->pa_ht;
3490 $label = $originLine->label;
3491 $array_options = $originLine->array_options;
3492 if (
$object->isSituationInvoice()) {
3493 $situation_percent = 0;
3495 $situation_percent = 100;
3498 $fk_unit = $originLine->fk_unit;
3499 $pu_ht_devise = $originLine->multicurrency_subprice;
3501 $res =
$object->addline($desc, $pu_ht, $qty, $txtva, $txlocaltax1, $txlocaltax2, $fk_product, $remise_percent, $date_start, $date_end, $fk_code_ventilation, $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);
3521 include DOL_DOCUMENT_ROOT.
'/core/actions_printing.inc.php';
3527 if (!empty(
$object->id) && $action ==
'send') {
3529 $object->getSommePaiement(-1);
3530 $object->getSumCreditNotesUsed(-1);
3531 $object->getSumDepositsUsed(-1);
3533 $triggersendname =
'BILL_SENTBYMAIL';
3535 $autocopy =
'MAIN_MAIL_AUTOCOPY_INVOICE_TO';
3536 $trackid =
'inv'.$object->id;
3537 include DOL_DOCUMENT_ROOT.
'/core/actions_sendmails.inc.php';
3541 $permissiontoadd = $usercancreate;
3542 include DOL_DOCUMENT_ROOT.
'/core/actions_builddoc.inc.php';
3545 if ($action ==
'update_extras' && $permissiontoeditextra) {
3548 $attribute_name =
GETPOST(
'attribute',
'aZ09');
3551 $ret = $extrafields->setOptionalsFromPost(
null,
$object, $attribute_name);
3558 $result =
$object->updateExtraField($attribute_name,
'BILL_MODIFY');
3566 $action =
'edit_extras';
3571 if ($action ==
'addcontact' && $usercancreate) {
3572 $result =
$object->fetch($id);
3574 if ($result > 0 && $id > 0) {
3577 $result =
$object->add_contact($contactid, $typeid,
GETPOST(
"source",
'aZ09'));
3581 header(
"Location: ".$_SERVER[
'PHP_SELF'].
"?id=".
$object->id);
3584 if (
$object->error ==
'DB_ERROR_RECORD_ALREADY_EXISTS') {
3585 $langs->load(
"errors");
3586 setEventMessages($langs->trans(
"ErrorThisContactIsAlreadyDefinedAsThisType"),
null,
'errors');
3591 } elseif ($action ==
'swapstatut' && $usercancreate) {
3598 } elseif ($action ==
'deletecontact' && $usercancreate) {
3601 $result =
$object->delete_contact($lineid);
3604 header(
"Location: ".$_SERVER[
'PHP_SELF'].
"?id=".
$object->id);
3612 $action =
'edit_extras';
3622$form =
new Form($db);
3628$bankaccountstatic =
new Account($db);
3630if (isModEnabled(
'project')) {
3636$title =
$object->ref.
" - ".$langs->trans(
'Card');
3637if ($action ==
'create') {
3638 $title = $langs->trans(
"NewBill");
3640$help_url =
"EN:Customers_Invoices|FR:Factures_Clients|ES:Facturas_a_clientes";
3646if ($action ==
'create') {
3647 $facturestatic =
new Facture($db);
3648 $extrafields->fetch_name_optionals_label($facturestatic->table_element);
3653 $res = $soc->fetch($socid);
3656 $currency_code =
$conf->currency;
3658 $cond_reglement_id =
GETPOSTINT(
'cond_reglement_id');
3659 $mode_reglement_id =
GETPOSTINT(
'mode_reglement_id');
3665 if (!empty($origin) && !empty($originid)) {
3667 $element = $subelement = $origin;
3669 if (preg_match(
'/^([^_]+)_([^_]+)/i', $origin, $regs)) {
3670 $element = $regs[1];
3671 $subelement = $regs[2];
3677 if ($element ==
'project') {
3678 $projectid = $originid;
3680 if (empty($cond_reglement_id)) {
3681 $cond_reglement_id = $soc->cond_reglement_id;
3683 if (empty($mode_reglement_id)) {
3684 $mode_reglement_id = $soc->mode_reglement_id;
3686 if (empty($fk_account)) {
3687 $fk_account = $soc->fk_account;
3689 if (empty($dateinvoice)) {
3695 if ($element ==
'order' || $element ==
'commande') {
3696 $element = $subelement =
'commande';
3698 if ($element ==
'propal') {
3699 $element =
'comm/propal';
3700 $subelement =
'propal';
3702 if ($element ==
'contract') {
3703 $element = $subelement =
'contrat';
3705 if ($element ==
'shipping') {
3706 $element = $subelement =
'expedition';
3711 $classname = ucfirst($subelement);
3712 $objectsrc =
new $classname($db);
3713 '@phan-var-force Commande|Propal|Contrat|Expedition $objectsrc';
3714 $objectsrc->fetch($originid);
3715 if (empty($objectsrc->lines) && method_exists($objectsrc,
'fetch_lines')) {
3716 $objectsrc->fetch_lines();
3718 $objectsrc->fetch_thirdparty();
3720 $projectid = (!empty($projectid) ? $projectid : $objectsrc->fk_project);
3726 $ref_client = (!empty($objectsrc->ref_client) ? $objectsrc->ref_client : (!empty($objectsrc->ref_customer) ? $objectsrc->ref_customer :
''));
3730 if (empty($socid)) {
3731 $soc = $objectsrc->thirdparty;
3734 $dateinvoice = (empty($dateinvoice) ? (!
getDolGlobalString(
'MAIN_AUTOFILL_DATE') ? -1 :
'') : $dateinvoice);
3736 if ($element ==
'expedition') {
3737 $elem = $subelem = $objectsrc->origin;
3738 $expeoriginid = $objectsrc->origin_id;
3740 $classname = ucfirst($subelem);
3742 $expesrc =
new $classname($db);
3743 '@phan-var-force Expedition $expesrc';
3744 dol_syslog(
"Is type Facture|Commande or Expedition: $element...expesrc($classname)=".get_class($expesrc));
3745 $expesrc->fetch($expeoriginid);
3747 $cond_reglement_id = (!empty($expesrc->cond_reglement_id) ? $expesrc->cond_reglement_id : (!empty($soc->cond_reglement_id) ? $soc->cond_reglement_id : 1));
3748 $mode_reglement_id = (!empty($expesrc->mode_reglement_id) ? $expesrc->mode_reglement_id : (!empty($soc->mode_reglement_id) ? $soc->mode_reglement_id : 0));
3749 $fk_account = (!empty($expesrc->fk_account) ? $expesrc->fk_account : (!empty($soc->fk_account) ? $soc->fk_account : 0));
3751 if (isModEnabled(
'multicurrency')) {
3752 $currency_code = (!empty($expesrc->multicurrency_code) ? $expesrc->multicurrency_code : (!empty($soc->multicurrency_code) ? $soc->multicurrency_code : $objectsrc->multicurrency_code));
3753 $currency_tx = (!empty($expesrc->multicurrency_tx) ? $expesrc->multicurrency_tx : (!empty($soc->multicurrency_tx) ? $soc->multicurrency_tx : $objectsrc->multicurrency_tx));
3757 $inputReasonId = (!empty($objectsrc->demand_reason_id) ? $objectsrc->demand_reason_id : (!empty($soc->demand_reason_id) ? $soc->demand_reason_id : 0));
3760 $expesrc->fetch_optionals();
3761 $object->array_options = $expesrc->array_options;
3763 $cond_reglement_id = (!empty($objectsrc->cond_reglement_id) ? $objectsrc->cond_reglement_id : (!empty($soc->cond_reglement_id) ? $soc->cond_reglement_id : (!empty($cond_reglement_id) ? $cond_reglement_id : 0)));
3764 $mode_reglement_id = (!empty($objectsrc->mode_reglement_id) ? $objectsrc->mode_reglement_id : (!empty($soc->mode_reglement_id) ? $soc->mode_reglement_id : (!empty($mode_reglement_id) ? $mode_reglement_id : 0)));
3765 $fk_account = (!empty($objectsrc->fk_account) ? $objectsrc->fk_account : (!empty($soc->fk_account) ? $soc->fk_account : (!empty($fk_account) ? $fk_account : 0)));
3767 if (isModEnabled(
'multicurrency')) {
3768 if (!empty($objectsrc->multicurrency_code)) {
3769 $currency_code = $objectsrc->multicurrency_code;
3771 if (
getDolGlobalString(
'MULTICURRENCY_USE_ORIGIN_TX') && !empty($objectsrc->multicurrency_tx)) {
3772 $currency_tx = $objectsrc->multicurrency_tx;
3777 $inputReasonId = (!empty($objectsrc->demand_reason_id) ? $objectsrc->demand_reason_id : (!empty($soc->demand_reason_id) ? $soc->demand_reason_id : 0));
3780 $objectsrc->fetch_optionals();
3781 $object->array_options = $objectsrc->array_options;
3785 $cond_reglement_id = empty($soc->cond_reglement_id) ? $cond_reglement_id : $soc->cond_reglement_id;
3786 $mode_reglement_id = empty($soc->mode_reglement_id) ? $mode_reglement_id : $soc->mode_reglement_id;
3787 $fk_account = empty($soc->fk_account) ? $fk_account : $soc->fk_account;
3788 $inputReasonId = empty($soc->demand_reason_id) ? $inputReasonId : $soc->demand_reason_id;
3790 $dateinvoice = (empty($dateinvoice) ? (!
getDolGlobalString(
'MAIN_AUTOFILL_DATE') ? -1 :
'') : $dateinvoice);
3792 if (isModEnabled(
'multicurrency') && !empty($soc->multicurrency_code)) {
3793 $currency_code = $soc->multicurrency_code;
3798 if (!
GETPOST(
'changecompany')) {
3799 if (GETPOSTISSET(
'cond_reglement_id')) {
3800 $cond_reglement_id =
GETPOSTINT(
'cond_reglement_id');
3802 if (GETPOSTISSET(
'mode_reglement_id')) {
3803 $mode_reglement_id =
GETPOSTINT(
'mode_reglement_id');
3805 if (GETPOSTISSET(
'cond_reglement_id')) {
3811 if (empty($cond_reglement_id)) {
3812 $cond_reglement_id =
GETPOSTINT(
"cond_reglement_id");
3816 if (empty($mode_reglement_id)) {
3817 $mode_reglement_id =
GETPOSTINT(
"mode_reglement_id");
3827 if (!empty($soc->id)) {
3828 $absolute_discount = $soc->getAvailableDiscounts();
3830 $note_public =
$object->getDefaultCreateValueFor(
'note_public', ((!empty($origin) && !empty($originid) && is_object($objectsrc) &&
getDolGlobalString(
'FACTURE_REUSE_NOTES_ON_CREATE_FROM')) ? $objectsrc->note_public : null));
3831 $note_private =
$object->getDefaultCreateValueFor(
'note_private', ((!empty($origin) && !empty($originid) && is_object($objectsrc) &&
getDolGlobalString(
'FACTURE_REUSE_NOTES_ON_CREATE_FROM')) ? $objectsrc->note_private : null));
3833 if (!empty(
$conf->use_javascript_ajax)) {
3834 require_once DOL_DOCUMENT_ROOT.
'/core/lib/ajax.lib.php';
3840 if ($origin ==
'contrat') {
3841 $langs->load(
"admin");
3842 $text = $langs->trans(
"ToCreateARecurringInvoice");
3843 $text .=
' '.$langs->trans(
"ToCreateARecurringInvoiceGene", $langs->transnoentitiesnoconv(
"MenuFinancial"), $langs->transnoentitiesnoconv(
"BillsCustomers"), $langs->transnoentitiesnoconv(
"ListOfTemplates"));
3845 $text .=
' '.$langs->trans(
"ToCreateARecurringInvoiceGeneAuto", $langs->transnoentitiesnoconv(
'Module2300Name'));
3847 print
info_admin($text, 0, 0,
'info',
'').
'<br>';
3850 print
'<form name="add" action="'.$_SERVER[
"PHP_SELF"].
'" method="POST" id="formtocreate" name="formtocreate">';
3851 print
'<input type="hidden" name="token" value="'.newToken().
'">';
3852 print
'<input type="hidden" name="action" id="formtocreateaction" value="add">';
3853 print
'<input type="hidden" name="changecompany" value="0">';
3855 print
'<input type="hidden" name="socid" value="'.$soc->id.
'">'.
"\n";
3857 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
3858 print
'<input name="ref" type="hidden" value="provisoire">';
3859 print
'<input name="ref_client" type="hidden" value="'.$ref_client.
'">';
3860 print
'<input name="force_cond_reglement_id" type="hidden" value="0">';
3861 print
'<input name="force_mode_reglement_id" type="hidden" value="0">';
3862 print
'<input name="force_fk_account" type="hidden" value="0">';
3863 print
'<input type="hidden" name="origin" value="'.$origin.
'">';
3864 print
'<input type="hidden" name="originid" value="'.$originid.
'">';
3865 print
'<input type="hidden" name="originentity" value="'.GETPOSTINT(
'originentity').
'">';
3866 if (!empty($currency_tx)) {
3867 print
'<input type="hidden" name="originmulticurrency_tx" value="'.$currency_tx.
'">';
3873 $parameters = array();
3875 $reshook = $hookmanager->executeHooks(
'tabContentCreateInvoice', $parameters,
$object, $action);
3876 if (empty($reshook)) {
3877 print
'<table class="border centpercent">';
3879 $exampletemplateinvoice =
new FactureRec($db);
3881 if (empty($origin) && empty($originid) &&
GETPOSTINT(
'fac_rec') > 0) {
3882 $invoice_predefined->fetch(
GETPOSTINT(
'fac_rec'));
3886 if ($soc->id > 0 && (!
GETPOSTINT(
'fac_rec') || !empty($invoice_predefined->frequency))) {
3888 print
'<tr><td class="fieldrequired titlefieldcreate">'.$langs->trans(
'Customer').
'</td>';
3889 print
'<td colspan="2">';
3890 print $soc->getNomUrl(1,
'customer');
3891 print
'<input type="hidden" name="socid" value="'.$soc->id.
'">';
3893 $arrayoutstandingbills = $soc->getOutstandingBills();
3894 $outstandingBills = $arrayoutstandingbills[
'opened'];
3895 print
' - <span class="opacitymedium valignmiddle">'.$langs->trans(
'CurrentOutstandingBill').
':</span> ';
3896 print
'<span class="amount valignmiddle">'.price($outstandingBills, 0, $langs, 0, 0, -1,
$conf->currency).
'</span>';
3897 if ($soc->outstanding_limit !=
'') {
3898 if ($outstandingBills > $soc->outstanding_limit) {
3899 print
img_warning($langs->trans(
"OutstandingBillReached"));
3901 print
' / '.price($soc->outstanding_limit, 0, $langs, 0, 0, -1,
$conf->currency);
3906 print
'<tr><td class="fieldrequired">'.$langs->trans(
'Customer').
'</td>';
3907 print
'<td colspan="2">';
3908 $filter =
'((s.client:IN:1,2,3) AND (s.status:=:1))';
3909 print
img_picto(
'',
'company',
'class="pictofixedwidth"').$form->select_company($soc->id,
'socid', $filter,
'SelectThirdParty', 1, 0, array(), 0,
'minwidth300 widthcentpercentminusxx maxwidth500');
3913 $(document).ready(function() {
3914 $("#socid").change(function() {
3916 console.log("Submit page");
3917 $(\'input[name="action"]\').val(\'create\');
3918 $(\'input[name="force_cond_reglement_id"]\').val(\'1\');
3919 $(\'input[name="force_mode_reglement_id"]\').val(\'1\');
3920 $(\'input[name="force_fk_account"]\').val(\'1\');
3921 $("#formtocreate").submit(); */
3923 // For company change, we must submit page with action=create instead of action=add
3924 console.log("We have changed the company - Resubmit page");
3925 jQuery("input[name=changecompany]").val("1");
3926 jQuery("#formtocreateaction").val("create");
3927 jQuery("#formtocreate").submit();
3933 print
' <a class="valignmiddle" href="'.DOL_URL_ROOT.
'/societe/card.php?action=create&customer=3&fournisseur=0&backtopage='.urlencode($_SERVER[
"PHP_SELF"].
'?action=create').
'"><span class="fa fa-plus-circle valignmiddle paddingleft" title="'.$langs->trans(
"AddThirdParty").
'"></span></a>';
3940 if (empty($origin) && empty($originid) &&
GETPOSTINT(
'fac_rec') > 0) {
3942 foreach ($invoice_predefined->array_options as $key => $option) {
3943 if (!isset(
$object->array_options[$key])) {
3944 $object->array_options[$key] = $invoice_predefined->array_options[$key];
3948 $dateinvoice = $invoice_predefined->date_when;
3949 if (empty($projectid)) {
3950 $projectid = $invoice_predefined->fk_project;
3952 $cond_reglement_id = $invoice_predefined->cond_reglement_id;
3953 $mode_reglement_id = $invoice_predefined->mode_reglement_id;
3954 $fk_account = $invoice_predefined->fk_account;
3955 $note_public = $invoice_predefined->note_public;
3956 $note_private = $invoice_predefined->note_private;
3958 if (!empty($invoice_predefined->multicurrency_code)) {
3959 $currency_code = $invoice_predefined->multicurrency_code;
3961 if (!empty($invoice_predefined->multicurrency_tx)) {
3962 $currency_tx = $invoice_predefined->multicurrency_tx;
3965 $sql =
'SELECT r.rowid, r.titre as title, r.total_ttc';
3966 $sql .=
' FROM '.MAIN_DB_PREFIX.
'facture_rec as r';
3967 $sql .=
' WHERE r.fk_soc = '.((int) $invoice_predefined->socid);
3969 $resql = $db->query($sql);
3971 $num = $db->num_rows($resql);
3975 print
'<tr><td>'.$langs->trans(
'CreateFromRepeatableInvoice').
'</td><td>';
3977 print
'<select class="flat" id="fac_rec" name="fac_rec">';
3978 print
'<option value="0" selected></option>';
3980 $objp = $db->fetch_object($resql);
3981 print
'<option value="'.$objp->rowid.
'"';
3984 $exampletemplateinvoice->fetch(
GETPOSTINT(
'fac_rec'));
3986 print
'>'.$objp->title.
' ('.
price($objp->total_ttc).
' '.$langs->trans(
"TTC").
')</option>';
3995 print
'<script type="text/javascript">
3996 $(document).ready(function() {
3997 $("#fac_rec").change(function() {
3998 console.log("We have changed the template invoice - Reload page");
3999 var fac_rec = $(this).val();
4000 var socid = $(\'#socid\').val();
4001 // For template invoice change, we must reuse data of template, not input already done, so we call a GET with action=create, not a POST submit.
4002 window.location.href = "'.$_SERVER[
"PHP_SELF"].
'?action=create&socid="+socid+"&fac_rec="+fac_rec;
4015 print
'<tr><td class="tdtop fieldrequired titlefieldcreate">'.$langs->trans(
'Type').
'</td><td colspan="2">';
4016 print
'<div class="listofinvoicetypetable">'.
"\n";
4019 print
'<div class="listofinvoicetype"><div class="">';
4020 $tmp =
'<input type="radio" id="radio_standard" name="type" value="0"'.(GETPOSTINT(
'type') ?
'' :
' checked').
'> ';
4021 $tmp = $tmp.
'<label for="radio_standard" >'.$langs->trans(
"InvoiceStandardAsk").
'</label>';
4023 $desc = $form->textwithpicto($tmp, $langs->transnoentities(
"InvoiceStandardDesc"), 1,
'help',
'nowraponall', 0, 3,
'standardonsmartphone');
4025 if ((($origin ==
'propal') || ($origin ==
'commande')) && (!empty($originid))) {
4035 print
'<span class="opacitymedium marginleftonly">' . $langs->trans(
'PercentOfOriginalObject') .
'</span>:<input class="right" placeholder="100%" type="text" id="valuestandardinvoice" name="valuestandardinvoice" size="3" value="' . (GETPOSTISSET(
'valuestandardinvoice') ?
GETPOST(
'valuestandardinvoice',
'alpha') :
'100%') .
'"/>';
4038 print
'</div></div>'.
"\n";
4040 if ((empty($origin)) || ((($origin ==
'propal') || ($origin ==
'commande')) && (!empty($originid)))) {
4043 print
'<div class="listofinvoicetype"><div class="">';
4044 $tmp =
'<input type="radio" id="radio_deposit" name="type" value="3"'.(GETPOSTINT(
'type') == 3 ?
' checked' :
'').
'> ';
4045 print
'<script type="text/javascript">
4046 jQuery(document).ready(function() {
4047 jQuery("#typestandardinvoice, #valuestandardinvoice").click(function() {
4048 jQuery("#radio_standard").prop("checked", true);
4050 jQuery("#typedeposit, #valuedeposit").click(function() {
4051 jQuery("#radio_deposit").prop("checked", true);
4053 jQuery("#typedeposit").change(function() {
4054 console.log("We change type of down payment: "+jQuery("#typedeposit").val());
4056 if (jQuery("#typedeposit").val() == "amount") {
4057 jQuery("#valuedeposit").attr("placeholder", "'.$langs->getCurrencySymbol(
$conf->currency).
'");
4058 jQuery("#valuedeposit").val("");
4060 jQuery("#valuedeposit").attr("placeholder", "50%");
4061 jQuery("#valuedeposit").val("");
4064 jQuery("#radio_deposit").prop("checked", true);
4065 setRadioForTypeOfInvoice();
4067 jQuery("#radio_standard, #radio_deposit, #radio_replacement, #radio_creditnote, #radio_template").change(function() {
4068 setRadioForTypeOfInvoice();
4071 function setRadioForTypeOfInvoice() {
4072 console.log("Change radio for type of invoice");
4073 if (jQuery("#radio_deposit").prop("checked") && (jQuery("#typedeposit").val() == \'amount\' || jQuery("#typedeposit").val() == \'variable\')) {
4074 jQuery("#checkforselects").prop("disabled", true);
4075 jQuery("#checkforselects").prop("checked", false);
4076 jQuery(".checkforselect").prop("disabled", true);
4077 jQuery(".checkforselect").prop("checked", false);
4079 jQuery("#checkforselects").prop("disabled", false);
4080 jQuery("#checkforselects").prop("checked", true);
4081 jQuery(".checkforselect").prop("disabled", false);
4082 jQuery(".checkforselect").prop("checked", true);
4088 $tmp = $tmp.
'<label for="radio_deposit">'.$langs->trans(
"InvoiceDeposit").
'</label>';
4090 $desc = $form->textwithpicto($tmp, $langs->transnoentities(
"InvoiceDepositDesc"), 1,
'help',
'', 0, 3,
'depositonsmartphone');
4092 if (($origin ==
'propal') || ($origin ==
'commande')) {
4095 'amount' => $langs->transnoentitiesnoconv(
'FixAmount', $langs->transnoentitiesnoconv(
'Deposit')),
4096 'variable' => $langs->transnoentitiesnoconv(
'VarAmountOneLine', $langs->transnoentitiesnoconv(
'Deposit')),
4097 'variablealllines' => $langs->transnoentitiesnoconv(
'VarAmountAllLines')
4101 'variablealllines' => $langs->transnoentitiesnoconv(
'VarAmountAllLines')
4105 $typedeposit =
GETPOST(
'typedeposit',
'aZ09');
4107 if (empty($typedeposit) && !empty($objectsrc->deposit_percent)) {
4108 $origin_payment_conditions_deposit_percent =
getDictionaryValue(
'c_payment_term',
'deposit_percent', $objectsrc->cond_reglement_id);
4109 if (!empty($origin_payment_conditions_deposit_percent)) {
4110 $typedeposit =
'variable';
4113 if (empty($valuedeposit) && $typedeposit ==
'variable' && !empty($objectsrc->deposit_percent)) {
4114 $valuedeposit = $objectsrc->deposit_percent;
4116 print
'<span class="marginleftonly">'.$form->selectarray(
'typedeposit', $arraylist, $typedeposit, 0, 0, 0,
'', 1).
'</span>';
4118 print
'<input type="text" id="valuedeposit" name="valuedeposit" class="width75 right" value="'.($valuedeposit ? $valuedeposit :
'').
'"'.($valuedeposit ?
'' :
'placeholder="'.$langs->getCurrencySymbol(
$conf->currency).
'"').
'>';
4121 print
'</div></div>'.
"\n";
4128 print
'<div class="listofinvoicetype"><div class="">';
4129 $tmp =
'<input id="radio_situation" type="radio" name="type" value="5"'.(GETPOST(
'type') == 5 ?
' checked' :
'').
'> ';
4130 $tmp = $tmp.
'<label for="radio_situation" >'.$langs->trans(
"InvoiceFirstSituationAsk").
'</label>';
4132 $desc = $form->textwithpicto($tmp, $langs->transnoentities(
"InvoiceFirstSituationDesc"), 1,
'help',
'', 0, 3,
'firstsituationonsmartphone');
4136 $opt = $form->selectSituationInvoices((
string)
GETPOSTINT(
'originid'), $socid);
4139 print
'</div></div><div class="listofinvoicetype"><div>';
4141 $tmp =
'<input id="radio_situation_bis" type="radio" name="type" value="5"'.(GETPOST(
'type') == 5 &&
GETPOSTINT(
'originid') ?
' checked' :
'');
4142 if ($opt == (
'<option value="0" selected>'.$langs->trans(
'NoSituations').
'</option>') || (
GETPOST(
'origin') &&
GETPOST(
'origin') !=
'facture' &&
GETPOST(
'origin') !=
'commande')) {
4143 $tmp .=
' disabled';
4146 $text = $tmp.
'<label for="radio_situation_bis">'.$langs->trans(
"InvoiceSituationAsk").
'</label> ';
4147 $text .=
'<select class="flat minwidth50" id="situations" name="situations"';
4148 if ($opt == (
'<option value="0" selected>'.$langs->trans(
'NoSituations').
'</option>') || (
GETPOST(
'origin') &&
GETPOST(
'origin') !=
'facture' &&
GETPOST(
'origin') !=
'commande')) {
4149 $text .=
' disabled';
4153 $text .=
'</select>';
4154 $desc = $form->textwithpicto($text, $langs->transnoentities(
"InvoiceSituationDesc"), 1,
'help',
'', 0, 3);
4156 print
'</div></div>'.
"\n";
4162 $facids = $facturestatic->list_replacable_invoices($soc->id);
4168 if (is_array($facids)) {
4169 foreach ($facids as $facparam) {
4170 $options .=
'<option value="'.$facparam [
'id'].
'"';
4171 if ($facparam[
'id'] ==
GETPOSTINT(
'fac_replacement')) {
4172 $options .=
' selected';
4174 $options .=
'>'.$facparam[
'ref'];
4175 $options .=
' ('.$facturestatic->LibStatut($facparam[
'paid'], $facparam[
'status'], 0, $facparam[
'alreadypaid']).
')';
4176 $options .=
'</option>';
4180 print
'<!-- replacement line -->';
4181 print
'<div class="listofinvoicetype"><div class="">';
4182 $tmp =
'<input type="radio" name="type" id="radio_replacement" value="1"'.(GETPOST(
'type') == 1 ?
' checked' :
'');
4183 if (!$options || $invoice_predefined->id > 0) {
4184 $tmp .=
' disabled';
4187 print
'<script type="text/javascript">
4188 jQuery(document).ready(function() {
4189 jQuery("#fac_replacement").change(function() {
4190 console.log("We change fac_replacement");
4191 jQuery("#radio_replacement").prop("checked", true);
4195 $text = $tmp.
'<label for="radio_replacement">'.$langs->trans(
"InvoiceReplacementAsk").
'</label>';
4196 $text .=
'<select class="flat" name="fac_replacement" id="fac_replacement"';
4197 if (!$options || $invoice_predefined->id > 0) {
4198 $text .=
' disabled';
4202 $text .=
'<option value="-1"> </option>';
4205 $text .=
'<option value="-1">'.$langs->trans(
"NoReplacableInvoice").
'</option>';
4207 $text .=
'</select>';
4208 $desc = $form->textwithpicto($text, $langs->transnoentities(
"InvoiceReplacementDesc"), 1,
'help',
'', 0, 3);
4210 print
'</div></div>'.
"\n";
4214 print
'<div class="listofinvoicetype"><div class="">';
4215 $tmp =
'<input type="radio" name="type" id="radio_situation" value="0" disabled> ';
4216 $text = $tmp.
'<label class="opacitymedium">'.$langs->trans(
"InvoiceSituationAsk").
'</label> ';
4217 $desc = $form->textwithpicto($text, $langs->transnoentities(
"InvoiceFirstSituationDesc").
'<br><br>'.$langs->trans(
"YouMustCreateInvoiceFromThird"), 1,
'help',
'nowraponall', 0, 3,
'firstsituationonsmartphone');
4219 print
'</div></div>'.
"\n";
4222 print
'<div class="listofinvoicetype"><div class="">';
4223 $tmp =
'<input type="radio" name="type" id="radio_replacement" value="0" disabled> ';
4224 $text = $tmp.
'<label for="radio_replacement" class="opacitymedium">'.$langs->trans(
"InvoiceReplacement").
'</label> ';
4225 $desc = $form->textwithpicto($text, $langs->transnoentities(
"InvoiceReplacementDesc").
'<br><br>'.$langs->trans(
"YouMustCreateInvoiceFromThird"), 1,
'help',
'nowraponall', 0, 3,
'replacementonsmartphone');
4227 print
'</div></div>'.
"\n";
4230 if (empty($origin)) {
4235 $facids = $facturestatic->list_qualified_avoir_invoices($soc->id);
4241 $newinvoice_static =
new Facture($db);
4242 foreach ($facids as $key => $valarray) {
4243 $newinvoice_static->id = $key;
4244 $newinvoice_static->ref = $valarray [
'ref'];
4245 $newinvoice_static->statut = $valarray [
'status'];
4246 $newinvoice_static->status = $valarray [
'status'];
4247 $newinvoice_static->type = $valarray [
'type'];
4248 $newinvoice_static->paye = $valarray [
'paye'];
4249 $newinvoice_static->paid = $valarray [
'paye'];
4251 $optionsav .=
'<option value="'.$key.
'"';
4252 if ($key ==
GETPOST(
'fac_avoir')) {
4253 $optionsav .=
' selected';
4256 $newinvoice_static->fetch_optionals($key);
4257 $object->array_options = $newinvoice_static->array_options;
4260 $optionsav .= $newinvoice_static->ref;
4261 $optionsav .=
' ('.$newinvoice_static->getLibStatut(1, $valarray [
'paymentornot']).
')';
4262 $optionsav .=
'</option>';
4265 print
'<div class="listofinvoicetype"><div class="">';
4266 $tmp =
'<input type="radio" id="radio_creditnote" name="type" value="2"'.(GETPOST(
'type') == 2 ?
' checked' :
'');
4267 if ((!$optionsav && !
getDolGlobalString(
'INVOICE_CREDIT_NOTE_STANDALONE')) || $invoice_predefined->id > 0) {
4268 $tmp .=
' disabled';
4272 print
'<script type="text/javascript">
4273 jQuery(document).ready(function() {
4274 if (jQuery("#radio_creditnote").is(":checked"))
4276 jQuery("#radio_standard").prop("disabled", true);
4278 jQuery("#radio_standard").prop("disabled", false);
4280 if (! jQuery("#radio_creditnote").is(":checked"))
4282 jQuery("#credit_note_options").hide();
4284 jQuery("#radio_creditnote").click(function() {
4286 jQuery("#credit_note_options").show();
4288 jQuery("#radio_standard, #radio_replacement, #radio_deposit, #radio_situation, #radio_situation_bis").click(function() {
4289 console.log("We click on a radio to close credit not options");
4290 jQuery("#credit_note_options").hide();
4294 $text =
'<label>'.$tmp.$langs->transnoentities(
"InvoiceAvoirAsk").
'</label> ';
4295 $text .=
'<select class="flat valignmiddle" name="fac_avoir" id="fac_avoir"';
4296 if (!$optionsav || $invoice_predefined->id > 0) {
4297 $text .=
' disabled';
4301 $text .=
'<option value="-1">'.$langs->trans(
"InvoiceAvoirAskCombo").
'</option>';
4302 $text .= $optionsav;
4304 $text .=
'<option value="-1">'.$langs->trans(
"NoInvoiceToCorrect").
'</option>';
4306 $text .=
'</select>';
4307 $desc = $form->textwithpicto($text, $langs->transnoentities(
"InvoiceAvoirDesc"), 1,
'help',
'', 0, 3);
4310 print
'<div id="credit_note_options" class="clearboth paddingtop marginbottomonly">';
4311 print
'<div class="marginleftlarge"><input type="checkbox" name="invoiceAvoirWithLines" id="invoiceAvoirWithLines" value="1" onclick="$(\'#credit_note_options input[type=checkbox]\').not(this).prop(\'checked\', false);" '.(GETPOSTINT(
'invoiceAvoirWithLines') > 0 ?
'checked' :
'').
' /> <label for="invoiceAvoirWithLines" class="small">'.$langs->trans(
'invoiceAvoirWithLines').
"</label></div>";
4313 print
'<div class="marginleftlarge"><input type="checkbox" name="invoiceAvoirWithPaymentRestAmount" id="invoiceAvoirWithPaymentRestAmount" value="1" onclick="$(\'#credit_note_options input[type=checkbox]\').not(this).prop(\'checked\', false);" '.(GETPOSTINT(
'invoiceAvoirWithPaymentRestAmount') > 0 ?
'checked' :
'').
' /> <label for="invoiceAvoirWithPaymentRestAmount" class="small">'.$langs->trans(
'invoiceAvoirWithPaymentRestAmount').
"</label></div>";
4316 print
'</div></div>'.
"\n";
4319 print
'<div class="listofinvoicetype"><div class="">';
4321 $tmp =
'<input type="radio" name="type" id="radio_creditnote" value="0" disabled> ';
4323 $tmp =
'<input type="radio" name="type" id="radio_creditnote" value="2" > ';
4325 $text = $tmp.
'<label class="opacitymedium" for="radio_creditnote">'.$langs->trans(
"InvoiceAvoir").
'</label> ';
4327 $desc = $form->textwithpicto($text, $langs->transnoentities(
"InvoiceAvoirDesc").
'<br><br>'.$langs->trans(
"CreateCreditNoteWhenClientInvoiceExists"), 1,
'help',
'', 0, 3,
'creditnoteonsmartphone');
4329 print
'</div></div>'.
"\n";
4334 print
'<div class="listofinvoicetype"><div class="">';
4335 $tmp =
'<input type="radio" name="type" id="radio_template" value="0" disabled> ';
4336 $text = $tmp.
'<label class="opacitymedium" for="radio_template">'.$langs->trans(
"RepeatableInvoice").
'</label> ';
4337 $desc = $form->textwithpicto($text, $langs->transnoentities(
"YouMustCreateStandardInvoiceFirstDesc"), 1,
'help',
'', 0, 3,
'templateonsmartphone');
4339 print
'</div></div>'.
"\n";
4348 foreach ($listtType as $type) {
4349 $thisTypeConfName =
'FACTURE_ADDON_PDF_'.$type;
4351 $jsListType .= (!empty($jsListType) ?
',' :
'').
'"'.$type.
'":"'.$current.
'"';
4354 print
'<script type="text/javascript">
4355 $(document).ready(function() {
4356 var listType = {'.$jsListType.
'};
4357 $("[name=\'type\'").change(function() {
4358 console.log("change name=type");
4359 if ($( this ).prop("checked"))
4361 if(($( this ).val() in listType))
4363 $("#model").val(listType[$( this ).val()]);
4380 print
'<tr><td class="fieldrequired">'.$langs->trans(
'InvoiceSubtype').
'</td><td colspan="2">';
4381 print $form->getSelectInvoiceSubtype(
GETPOSTINT(
'subtype'),
'subtype', 1, 0,
'');
4387 print
'<tr><td>'.$langs->trans(
'DiscountStillRemaining').
'</td><td colspan="2">';
4391 $backtopage = $_SERVER[
"PHP_SELF"].
'?socid='.$thirdparty->id.
'&action='.$action.
'&origin='.urlencode((
string) (
GETPOST(
'origin'))).
'&originid='.urlencode((
string) (
GETPOSTINT(
'originid')));
4392 include DOL_DOCUMENT_ROOT.
'/core/tpl/object_discounts.tpl.php';
4401 print
'<tr><td class="fieldrequired">'.$langs->trans(
'DateInvoice').
'</td><td colspan="2">';
4402 print
img_picto(
'',
'action',
'class="pictofixedwidth"');
4403 print $form->selectDate($newdateinvoice ? $newdateinvoice : $dateinvoice,
'', 0, 0, 0,
"add", 1, 1);
4408 print
'<tr><td class="fieldrequired">'.$langs->trans(
'DatePointOfTax').
'</td><td colspan="2">';
4409 print
img_picto(
'',
'action',
'class="pictofixedwidth"');
4410 print $form->selectDate($date_pointoftax ? $date_pointoftax : -1,
'date_pointoftax', 0, 0, 0,
"add", 1, 1);
4415 print
'<tr><td class="nowrap fieldrequired">'.$langs->trans(
'PaymentConditionsShort').
'</td><td colspan="2">';
4416 print
img_picto(
'',
'payment',
'class="pictofixedwidth"');
4417 print $form->getSelectConditionsPaiements((
int) $cond_reglement_id,
'cond_reglement_id', -1, 1, 0,
'maxwidth500 widthcentpercentminusx');
4422 $rwStyle =
'display:none;';
4423 if (in_array(
GETPOSTINT(
'type'), $retainedWarrantyInvoiceAvailableType)) {
4427 $retained_warranty =
GETPOSTINT(
'retained_warranty');
4428 if (empty($retained_warranty)) {
4429 if ($objectsrc !==
null && property_exists($objectsrc,
'retained_warranty') && !empty($objectsrc->retained_warranty)) {
4431 $retained_warranty = $objectsrc->retained_warranty;
4434 $retained_warranty_js_default = !empty($retained_warranty) ? $retained_warranty :
getDolGlobalString(
'INVOICE_SITUATION_DEFAULT_RETAINED_WARRANTY_PERCENT');
4436 print
'<tr class="retained-warranty-line" style="'.$rwStyle.
'" ><td class="nowrap">'.$langs->trans(
'RetainedWarranty').
'</td><td colspan="2">';
4437 print
'<input id="new-situation-invoice-retained-warranty" name="retained_warranty" type="number" value="'.$retained_warranty.
'" step="0.01" min="0" max="100" />%';
4440 print
'<tr class="retained-warranty-line" style="'.$rwStyle.
'" ><td class="nowrap">'.$langs->trans(
'PaymentConditionsShortRetainedWarranty').
'</td><td colspan="2">';
4441 $retained_warranty_fk_cond_reglement =
GETPOSTINT(
'retained_warranty_fk_cond_reglement');
4442 if (empty($retained_warranty_fk_cond_reglement)) {
4443 $retained_warranty_fk_cond_reglement =
getDolGlobalString(
'INVOICE_SITUATION_DEFAULT_RETAINED_WARRANTY_COND_ID');
4444 if (!empty($objectsrc->retained_warranty_fk_cond_reglement)) {
4445 $retained_warranty_fk_cond_reglement = $objectsrc->retained_warranty_fk_cond_reglement;
4447 $retained_warranty_fk_cond_reglement =
getDolGlobalString(
'INVOICE_SITUATION_DEFAULT_RETAINED_WARRANTY_COND_ID');
4450 print $form->getSelectConditionsPaiements($retained_warranty_fk_cond_reglement,
'retained_warranty_fk_cond_reglement', -1, 1);
4453 print
'<script type="text/javascript">
4454 $(document).ready(function() {
4455 $("[name=\'type\']").change(function() {
4456 if($( this ).prop("checked") && $.inArray($( this ).val(), '.json_encode($retainedWarrantyInvoiceAvailableType).
' ) !== -1)
4458 $(".retained-warranty-line").show();
4459 $("#new-situation-invoice-retained-warranty").val("'.(float) $retained_warranty_js_default.
'");
4462 $(".retained-warranty-line").hide();
4463 $("#new-situation-invoice-retained-warranty").val("");
4467 $("[name=\'type\']:checked").trigger("change");
4473 print
'<tr><td>'.$langs->trans(
'PaymentMode').
'</td><td colspan="2">';
4474 print
img_picto(
'',
'bank',
'class="pictofixedwidth"');
4475 print $form->select_types_paiements((
string) $mode_reglement_id,
'mode_reglement_id',
'CRDT', 0, 1, 0, 0, 1,
'maxwidth250 widthcentpercentminusx', 1);
4479 if (isModEnabled(
"bank")) {
4480 print
'<tr><td>'.$langs->trans(
'BankAccount').
'</td><td colspan="2">';
4481 print
img_picto(
'',
'bank_account',
'class="pictofixedwidth"');
4482 print $form->select_comptes($fk_account,
'fk_account', 0,
'', 1,
'', 0,
'maxwidth250 widthcentpercentminusx', 1);
4488 print
'<tr><td>'.$langs->trans(
'Source').
'</td><td>';
4489 print
img_picto(
'',
'question',
'class="pictofixedwidth"');
4490 $form->selectInputReason((
string) $inputReasonId,
'input_reason_id',
'', 1,
'maxwidth200 widthcentpercentminusx');
4494 if (isModEnabled(
'project') && is_object($formproject)) {
4495 $langs->load(
'projects');
4496 print
'<tr><td>'.$langs->trans(
'Project').
'</td><td colspan="2">';
4497 print
img_picto(
'',
'project',
'class="pictofixedwidth"');
4499 print $formproject->select_projects((($socid > 0 && !
getDolGlobalString(
'PROJECT_CAN_ALWAYS_LINK_TO_ALL_CUSTOMERS')) ? $socid : -1), (string) $projectid,
'projectid', 0, 0, 1, 1, 0, 0, 0,
'', 1, 0,
'maxwidth500 widthcentpercentminusxx');
4500 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 :
'')).
'"><span class="fa fa-plus-circle valignmiddle" title="'.$langs->trans(
"AddProject").
'"></span></a>';
4505 if (isModEnabled(
'incoterm')) {
4507 print
'<td><label for="incoterm_id">'.$form->textwithpicto($langs->trans(
"IncotermLabel"), !empty($objectsrc->label_incoterms) ? $objectsrc->label_incoterms :
'', 1).
'</label></td>';
4508 print
'<td colspan="2" class="maxwidthonsmartphone">';
4509 $incoterm_id =
GETPOST(
'incoterm_id');
4510 $location_incoterms =
GETPOST(
'location_incoterms');
4511 if (empty($incoterm_id)) {
4512 $incoterm_id = (!empty($objectsrc->fk_incoterms) ? $objectsrc->fk_incoterms : $soc->fk_incoterms);
4513 $location_incoterms = (!empty($objectsrc->location_incoterms) ? $objectsrc->location_incoterms : $soc->location_incoterms);
4515 print
img_picto(
'',
'incoterm',
'class="pictofixedwidth"');
4516 print $form->select_incoterms($incoterm_id, $location_incoterms);
4521 if (isModEnabled(
'category')) {
4523 print
'<tr><td>'.$langs->trans(
"Categories").
'</td><td colspan="3">';
4524 print $form->selectCategories(Categorie::TYPE_INVOICE,
'categories',
$object);
4529 $parameters = array(
'objectsrc' => !empty($objectsrc) ? $objectsrc : 0,
'colspan' =>
' colspan="2"',
'cols' =>
'2',
'socid' => $socid);
4530 $reshook = $hookmanager->executeHooks(
'formObjectOptions', $parameters,
$object, $action);
4531 print $hookmanager->resPrint;
4532 if (empty($reshook)) {
4533 if (
getDolGlobalString(
'THIRDPARTY_PROPAGATE_EXTRAFIELDS_TO_INVOICE') && !empty($soc->id)) {
4536 $tpExtrafieldLabels = $tpExtrafields->fetch_name_optionals_label($soc->table_element);
4537 if ($soc->fetch_optionals() > 0) {
4538 $object->array_options = array_merge(
$object->array_options, $soc->array_options);
4542 print
$object->showOptionals($extrafields,
'create', $parameters);
4546 print
'<tr><td>'.$langs->trans(
'Model').
'</td>';
4547 print
'<td colspan="2">';
4548 print
img_picto(
'',
'pdf',
'class="pictofixedwidth"');
4549 include_once DOL_DOCUMENT_ROOT.
'/core/modules/facture/modules_facture.php';
4554 $paramkey =
'FACTURE_ADDON_PDF_'.$type;
4559 print $form->selectarray(
'model', $liste, $preselected, 0, 0, 0,
'', 0, 0, 0,
'',
'maxwidth200 widthcentpercentminusx', 1);
4563 if (isModEnabled(
'multicurrency')) {
4565 print
'<td>'.$form->editfieldkey(
'Currency',
'multicurrency_code',
'',
$object, 0).
'</td>';
4566 print
'<td colspan="2" class="maxwidthonsmartphone">';
4567 print
img_picto(
'',
'currency',
'class="pictofixedwidth"');
4568 print $form->selectMultiCurrency(((GETPOSTISSET(
'multicurrency_code') && !
GETPOST(
'changecompany')) ?
GETPOST(
'multicurrency_code') : $currency_code),
'multicurrency_code', 0,
'', false,
'maxwidth200 widthcentpercentminusx');
4575 $dateexample = ($newdateinvoice ? $newdateinvoice : $dateinvoice);
4576 if (empty($dateexample)) {
4579 $substitutionarray = array(
4580 '__TOTAL_HT__' => $langs->trans(
"AmountHT").
' ('.$langs->trans(
"Example").
': '.
price($exampletemplateinvoice->total_ht).
')',
4581 '__TOTAL_TTC__' => $langs->trans(
"AmountTTC").
' ('.$langs->trans(
"Example").
': '.
price($exampletemplateinvoice->total_ttc).
')',
4582 '__INVOICE_PREVIOUS_MONTH__' => $langs->trans(
"PreviousMonthOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date(
dol_time_plus_duree($dateexample, -1,
'm'),
'%m').
')',
4583 '__INVOICE_MONTH__' => $langs->trans(
"MonthOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date($dateexample,
'%m').
')',
4584 '__INVOICE_NEXT_MONTH__' => $langs->trans(
"NextMonthOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date(
dol_time_plus_duree($dateexample, 1,
'm'),
'%m').
')',
4585 '__INVOICE_PREVIOUS_MONTH_TEXT__' => $langs->trans(
"TextPreviousMonthOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date(
dol_time_plus_duree($dateexample, -1,
'm'),
'%B').
')',
4586 '__INVOICE_MONTH_TEXT__' => $langs->trans(
"TextMonthOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date($dateexample,
'%B').
')',
4587 '__INVOICE_NEXT_MONTH_TEXT__' => $langs->trans(
"TextNextMonthOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date(
dol_time_plus_duree($dateexample, 1,
'm'),
'%B').
')',
4588 '__INVOICE_PREVIOUS_YEAR__' => $langs->trans(
"PreviousYearOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date(
dol_time_plus_duree($dateexample, -1,
'y'),
'%Y').
')',
4589 '__INVOICE_YEAR__' => $langs->trans(
"YearOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date($dateexample,
'%Y').
')',
4590 '__INVOICE_NEXT_YEAR__' => $langs->trans(
"NextYearOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date(
dol_time_plus_duree($dateexample, 1,
'y'),
'%Y').
')'
4593 $htmltext =
'<i>'.$langs->trans(
"FollowingConstantsWillBeSubstituted").
':<br>';
4594 foreach ($substitutionarray as $key => $val) {
4595 $htmltext .= $key.
' = '.$langs->trans($val).
'<br>';
4597 $htmltext .=
'</i>';
4602 print
'<td class="tdtop">';
4603 print $form->textwithpicto($langs->trans(
'NotePublic'), $htmltext);
4605 print
'<td valign="top" colspan="2">';
4606 $doleditor =
new DolEditor(
'note_public', (
string) $note_public,
'', 80,
'dolibarr_notes',
'In',
false,
false, !
getDolGlobalString(
'FCKEDITOR_ENABLE_NOTE_PUBLIC') ? 0 : 1, ROWS_3,
'90%');
4607 print $doleditor->Create(1);
4610 if (empty($user->socid)) {
4612 print
'<td class="tdtop">';
4613 print $form->textwithpicto($langs->trans(
'NotePrivate'), $htmltext);
4615 print
'<td valign="top" colspan="2">';
4616 $doleditor =
new DolEditor(
'note_private', (
string) $note_private,
'', 80,
'dolibarr_notes',
'In',
false,
false, !
getDolGlobalString(
'FCKEDITOR_ENABLE_NOTE_PRIVATE') ? 0 : 1, ROWS_3,
'90%');
4617 print $doleditor->Create(1);
4623 if (!empty($origin) && !empty($originid) && is_object($objectsrc)) {
4624 $langs->loadLangs(array(
'orders',
'propal'));
4627 if ($origin ==
'contrat') {
4628 '@phan-var-force Contrat $objectsrc';
4630 $objectsrc->update_price(1,
'auto', 1);
4633 print
"\n<!-- Show ref of origin ".$classname.
" -->\n";
4634 print
'<input type="hidden" name="amount" value="'.$objectsrc->total_ht.
'">'.
"\n";
4635 print
'<input type="hidden" name="total" value="'.$objectsrc->total_ttc.
'">'.
"\n";
4636 print
'<input type="hidden" name="tva" value="'.$objectsrc->total_tva.
'">'.
"\n";
4641 switch (get_class($objectsrc)) {
4643 $newclassname =
'CommercialProposal';
4646 $newclassname =
'Order';
4649 $newclassname =
'Sending';
4652 $newclassname =
'Contract';
4655 $newclassname =
'Intervention';
4658 $newclassname = get_class($objectsrc);
4662 print
'<tr><td>'.$langs->trans($newclassname).
'</td>';
4663 print
'<td colspan="2">';
4664 print $objectsrc->getNomUrl(1);
4666 $objectsrc->fetchObjectLinked($originid, $origin,
null,
'facture');
4667 if (isset($objectsrc->linkedObjects[
'facture']) && is_array($objectsrc->linkedObjects[
'facture']) && count($objectsrc->linkedObjects[
'facture']) >= 1) {
4669 echo
' - '.$langs->trans(
'LatestRelatedBill').
' '.end($objectsrc->linkedObjects[
'facture'])->getNomUrl(1);
4673 print
'<tr><td>'.$langs->trans(
'AmountHT').
'</td><td colspan="2">'.
price($objectsrc->total_ht, 1, $langs, 1, -1,
'',
$conf->currency).
'</td></tr>';
4674 print
'<tr><td>'.$langs->trans(
'AmountVAT').
'</td><td colspan="2">'.
price($objectsrc->total_tva, 1, $langs, 1, -1,
'',
$conf->currency).
"</td></tr>";
4675 if ($mysoc->localtax1_assuj ==
"1" || $objectsrc->total_localtax1 != 0) {
4676 print
'<tr><td>'.$langs->transcountry(
"AmountLT1", $mysoc->country_code).
'</td><td colspan="2">'.
price($objectsrc->total_localtax1, 1, $langs, 1, -1,
'',
$conf->currency).
"</td></tr>";
4679 if ($mysoc->localtax2_assuj ==
"1" || $objectsrc->total_localtax2 != 0) {
4680 print
'<tr><td>'.$langs->transcountry(
"AmountLT2", $mysoc->country_code).
'</td><td colspan="2">'.
price($objectsrc->total_localtax2, 1, $langs, 1, -1,
'',
$conf->currency).
"</td></tr>";
4682 print
'<tr><td>'.$langs->trans(
'AmountTTC').
'</td><td colspan="2">'.
price($objectsrc->total_ttc, 1, $langs, 1, -1,
'',
$conf->currency).
"</td></tr>";
4684 if (isModEnabled(
'multicurrency') && $objectsrc->multicurrency_code !=
$conf->currency) {
4686 print
'<tr><td>'.$langs->trans(
'MulticurrencyAmountHT').
'</td><td colspan="2">'.
price($objectsrc->multicurrency_total_ht, 1, $langs, 1, -1,
'', $objectsrc->multicurrency_code).
'</td></tr>';
4687 print
'<tr><td>'.$langs->trans(
'MulticurrencyAmountVAT').
'</td><td colspan="2">'.
price($objectsrc->multicurrency_total_tva, 1, $langs, 1, -1,
'', $objectsrc->multicurrency_code).
"</td></tr>";
4688 print
'<tr><td>'.$langs->trans(
'MulticurrencyAmountTTC').
'</td><td colspan="2">'.
price($objectsrc->multicurrency_total_ttc, 1, $langs, 1, -1,
'', $objectsrc->multicurrency_code).
"</td></tr>";
4696 print $form->buttonsSaveCancel(
"CreateDraft");
4699 if (!empty($origin) && !empty($originid) && is_object($objectsrc)) {
4702 $title = $langs->trans(
'ProductsAndServices');
4705 print
'<div class="div-table-responsive-no-min">';
4706 print
'<table class="noborder centpercent">';
4708 $objectsrc->printOriginLinesList(
'', $selectedLines);
4715} elseif ($id > 0 || !empty($ref)) {
4717 $langs->load(
'errors');
4718 echo
'<div class="error">'.$langs->trans(
"ErrorRecordNotFound").
'</div>';
4727 if ($user->socid > 0 && $user->socid !=
$object->socid) {
4731 $result =
$object->fetch_thirdparty();
4733 $result = $soc->fetch(
$object->socid);
4737 $selleruserevenustamp = $mysoc->useRevenueStamp();
4739 $totalpaid =
$object->getSommePaiement();
4740 $totalcreditnotes =
$object->getSumCreditNotesUsed();
4741 $totaldeposits =
$object->getSumDepositsUsed();
4747 $resteapayer =
price2num(
$object->total_ttc - $totalpaid - $totalcreditnotes - $totaldeposits,
'MT');
4750 if (isModEnabled(
'multicurrency')) {
4751 $multicurrency_totalpaid =
$object->getSommePaiement(1);
4752 $multicurrency_totalcreditnotes =
$object->getSumCreditNotesUsed(1);
4753 $multicurrency_totaldeposits =
$object->getSumDepositsUsed(1);
4754 $multicurrency_resteapayer =
price2num(
$object->multicurrency_total_ttc - $multicurrency_totalpaid - $multicurrency_totalcreditnotes - $multicurrency_totaldeposits,
'MT');
4758 if ($resteapayer == 0 && $multicurrency_resteapayer != 0 &&
$object->multicurrency_code !=
$conf->currency) {
4759 $resteapayer =
price2num((
float) $multicurrency_resteapayer /
$object->multicurrency_tx,
'MT');
4763 if (
$object->paye ||
$object->status == $object::STATUS_CLOSED) {
4766 $resteapayeraffiche = $resteapayer;
4769 $filterabsolutediscount =
"fk_facture_source IS NULL";
4770 $filtercreditnote =
"fk_facture_source IS NOT NULL";
4772 $filterabsolutediscount =
"fk_facture_source IS NULL OR (description LIKE '(DEPOSIT)%' AND description NOT LIKE '(EXCESS RECEIVED)%')";
4773 $filtercreditnote =
"fk_facture_source IS NOT NULL AND (description NOT LIKE '(DEPOSIT)%' OR description LIKE '(EXCESS RECEIVED)%')";
4776 $absolute_discount = $soc->getAvailableDiscounts(
null, $filterabsolutediscount);
4777 $absolute_creditnote = $soc->getAvailableDiscounts(
null, $filtercreditnote);
4778 $absolute_discount =
price2num($absolute_discount,
'MT');
4779 $absolute_creditnote =
price2num($absolute_creditnote,
'MT');
4781 $author =
new User($db);
4782 if (
$object->user_creation_id) {
4783 $author->fetch(
$object->user_creation_id);
4786 $objectidnext =
$object->getIdReplacingInvoice();
4790 print
dol_get_fiche_head($head,
'compta', $langs->trans(
'InvoiceCustomer'), -1,
'bill');
4795 if ($action ==
'converttoreduc') {
4797 $type_fac =
'ExcessReceived';
4799 $type_fac =
'CreditNote';
4801 $type_fac =
'Deposit';
4805 $text = $langs->trans(
'ConfirmConvertToReduc', strtolower($langs->transnoentities($type_fac)));
4806 $text .=
'<br>'.$langs->trans(
'ConfirmConvertToReduc2');
4807 $formconfirm = $form->formconfirm($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, $langs->trans(
'ConvertToReduc'), $text,
'confirm_converttoreduc',
'',
"yes", 2);
4811 if ($action ==
'delete') {
4812 $text = $langs->trans(
'ConfirmDeleteBill',
$object->ref);
4813 $formquestion = array();
4816 $qualified_for_stock_change = 0;
4818 $qualified_for_stock_change =
$object->hasProductsOrServices(2);
4820 $qualified_for_stock_change =
$object->hasProductsOrServices(1);
4823 if ($qualified_for_stock_change) {
4824 $langs->load(
"stocks");
4825 require_once DOL_DOCUMENT_ROOT.
'/product/class/html.formproduct.class.php';
4829 if (
$conf->browser->name ==
'ie') {
4832 $formquestion = array(
4836 array(
'type' =>
'other',
'name' =>
'idwarehouse',
'label' => $label,
'value' => $formproduct->selectWarehouses(
GETPOST(
'idwarehouse') ?
GETPOST(
'idwarehouse') :
'ifone',
'idwarehouse',
'', 1, 0, 0, $langs->trans(
"NoStockAction"), 0, $forcecombo))
4838 $formconfirm = $form->formconfirm($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, $langs->trans(
'DeleteBill'), $text,
'confirm_delete', $formquestion,
"yes", 1);
4840 $formconfirm = $form->formconfirm($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, $langs->trans(
'DeleteBill'), $text,
'confirm_delete',
'',
'no', 1);
4843 $formconfirm = $form->formconfirm($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, $langs->trans(
'DeleteBill'), $text,
'confirm_delete',
'',
'no', 1);
4848 if ($action ==
'situationout') {
4849 $text = $langs->trans(
'ConfirmRemoveSituationFromCycle',
$object->ref);
4850 $label = $langs->trans(
"ConfirmOuting");
4851 $formquestion = array();
4856 &&
$object->is_last_in_cycle()
4857 && $usercanunvalidate
4859 $formconfirm = $form->formconfirm($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, $label, $text,
'confirm_situationout', $formquestion,
"yes", 1);
4864 if ($action ==
'valid') {
4866 $objectref = substr(
$object->ref, 1, 4);
4867 if ($objectref ==
'PROV') {
4871 $object->date_lim_reglement =
$object->calculate_date_lim_reglement();
4873 $numref =
$object->getNextNumRef($soc);
4879 $text = $langs->trans(
'ConfirmValidateBill', $numref);
4881 $text .=
'<br><br>';
4882 $text .=
img_picto(
'',
'warning',
'class="pictofixedwidth"').
' '.$langs->trans(
'WarningInvoiceCanNeverBeEdited');
4884 if (isModEnabled(
'notification')) {
4885 require_once DOL_DOCUMENT_ROOT.
'/core/class/notify.class.php';
4886 $notify =
new Notify($db);
4888 $text .= $notify->confirmMessage(
'BILL_VALIDATE',
$object->socid,
$object);
4890 $formquestion = array();
4893 $qualified_for_stock_change = 0;
4895 $qualified_for_stock_change =
$object->hasProductsOrServices(2);
4897 $qualified_for_stock_change =
$object->hasProductsOrServices(1);
4900 if ($qualified_for_stock_change) {
4901 $langs->load(
"stocks");
4902 require_once DOL_DOCUMENT_ROOT.
'/product/class/html.formproduct.class.php';
4903 require_once DOL_DOCUMENT_ROOT.
'/product/stock/class/entrepot.class.php';
4906 $warehouse_array = $warehouse->list_array();
4907 if (count($warehouse_array) == 1) {
4908 $label =
$object->type ==
Facture::TYPE_CREDIT_NOTE ? $langs->trans(
"WarehouseForStockIncrease", current($warehouse_array)) : $langs->trans(
"WarehouseForStockDecrease", current($warehouse_array));
4909 $value =
'<input type="hidden" id="idwarehouse" name="idwarehouse" value="'.key($warehouse_array).
'">';
4912 $value = $formproduct->selectWarehouses(
GETPOST(
'idwarehouse') ?
GETPOST(
'idwarehouse') :
'ifone',
'idwarehouse',
'', 1);
4914 $formquestion = array(
4920 array(
'type' =>
'other',
'name' =>
'idwarehouse',
'label' => $label,
'value' => $value));
4924 $text .=
'<br>'.img_warning().
' '.$langs->trans(
"ErrorInvoiceOfThisTypeMustBePositive");
4929 foreach (
$object->lines as $line) {
4930 $res = $line->fetch_product();
4932 if ($line->product->isService() && $line->product->isMandatoryPeriod() && (empty($line->date_start) || empty($line->date_end))) {
4938 if ($nbMandated > 0) {
4940 setEventMessages($langs->trans(
"mandatoryPeriodNeedTobeSetMsgValidate"),
null,
'errors');
4943 $text .=
'<div><span class="clearboth nowraponall warning">'.img_warning().$langs->trans(
"mandatoryPeriodNeedTobeSetMsgValidate").
'</span></div>';
4948 $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, 260);
4953 if ($action ==
'modif') {
4954 $text = $langs->trans(
'ConfirmUnvalidateBill',
$object->ref);
4955 $formquestion = array();
4958 $qualified_for_stock_change = 0;
4960 $qualified_for_stock_change =
$object->hasProductsOrServices(2);
4962 $qualified_for_stock_change =
$object->hasProductsOrServices(1);
4965 if ($qualified_for_stock_change) {
4966 $langs->load(
"stocks");
4967 require_once DOL_DOCUMENT_ROOT.
'/product/class/html.formproduct.class.php';
4968 require_once DOL_DOCUMENT_ROOT.
'/product/stock/class/entrepot.class.php';
4971 $warehouse_array = $warehouse->list_array();
4972 if (count($warehouse_array) == 1) {
4973 $label =
$object->type ==
Facture::TYPE_CREDIT_NOTE ? $langs->trans(
"WarehouseForStockDecrease", current($warehouse_array)) : $langs->trans(
"WarehouseForStockIncrease", current($warehouse_array));
4974 $value =
'<input type="hidden" id="idwarehouse" name="idwarehouse" value="'.key($warehouse_array).
'">';
4977 $value = $formproduct->selectWarehouses(
GETPOST(
'idwarehouse') ?
GETPOST(
'idwarehouse') :
'ifone',
'idwarehouse',
'', 1);
4979 $formquestion = array(
4985 array(
'type' =>
'other',
'name' =>
'idwarehouse',
'label' => $label,
'value' => $value));
4989 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?facid='.
$object->id, $langs->trans(
'UnvalidateBill'), $text,
'confirm_modif', $formquestion,
"yes", 1);
4993 if ($action ==
'paid' && ($resteapayer <= 0 || (
getDolGlobalString(
'INVOICE_CAN_SET_PAID_EVEN_IF_PARTIALLY_PAID') && $resteapayer ==
$object->total_ttc))) {
4994 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?facid='.
$object->id, $langs->trans(
'ClassifyPaid'), $langs->trans(
'ConfirmClassifyPaidBill',
$object->ref),
'confirm_paid',
'',
"yes", 1);
4996 if ($action ==
'paid' && $resteapayer > 0 && (!
getDolGlobalString(
'INVOICE_CAN_SET_PAID_EVEN_IF_PARTIALLY_PAID') || $resteapayer !=
$object->total_ttc)) {
5000 $close[$i][
'code'] = $object::CLOSECODE_DISCOUNTVAT;
5002 $close[$i][
'code'] = $object::CLOSECODE_BADDEBT;
5004 $close[$i][
'code'] = $object::CLOSECODE_BANKCHARGE;
5006 $close[$i][
'code'] = $object::CLOSECODE_WITHHOLDINGTAX;
5008 $close[$i][
'code'] = $object::CLOSECODE_OTHER;
5012 $close[$i][
'label'] = $langs->trans(
"HelpEscompte").
'<br><br>'.$langs->trans(
"ConfirmClassifyPaidPartiallyReasonDiscountVatDesc");
5014 $close[$i][
'label'] = $langs->trans(
"ConfirmClassifyPaidPartiallyReasonBadCustomerDesc");
5016 $close[$i][
'label'] = $langs->trans(
"ConfirmClassifyPaidPartiallyReasonBankChargeDesc");
5018 $close[$i][
'label'] = $langs->trans(
"ConfirmClassifyPaidPartiallyReasonWithholdingTaxDesc");
5020 $close[$i][
'label'] = $langs->trans(
"Other");
5024 $close[$i][
'reason'] = $form->textwithpicto($langs->transnoentities(
"ConfirmClassifyPaidPartiallyReasonDiscount", $resteapayer, $langs->trans(
"Currency".$conf->currency)), $close[$i][
'label'], 1);
5026 $close[$i][
'reason'] = $form->textwithpicto($langs->transnoentities(
"ConfirmClassifyPaidPartiallyReasonBadCustomer", $resteapayer, $langs->trans(
"Currency".$conf->currency)), $close[$i][
'label'], 1);
5028 $close[$i][
'reason'] = $form->textwithpicto($langs->transnoentities(
"ConfirmClassifyPaidPartiallyReasonBankCharge", $resteapayer, $langs->trans(
"Currency".$conf->currency)), $close[$i][
'label'], 1);
5030 $close[$i][
'reason'] = $form->textwithpicto($langs->transnoentities(
"ConfirmClassifyPaidPartiallyReasonWithholdingTax"), $close[$i][
'label'], 1);
5032 $close[$i][
'reason'] = $form->textwithpicto($langs->transnoentities(
"Other"), $close[$i][
'label'], 1);
5036 foreach ($close as $key => $val) {
5037 $arrayreasons[$close[$key][
'code']] =
'<span class="small">'.$close[$key][
'reason'].
'</span>';
5041 $formquestion = array(
5042 'text' => $langs->trans(
"ConfirmClassifyPaidPartiallyQuestion"),
5043 0 => array(
'type' =>
'radio',
'name' =>
'close_code',
'label' =>
'',
'values' => $arrayreasons),
5044 1 => array(
'type' =>
'text',
'name' =>
'close_note',
'moreattr' =>
'placeholder = "'.$langs->trans(
"Comment").
'"',
'value' =>
'',
'morecss' =>
'minwidth300'),
5045 2 => array(
'type' =>
'separator')
5048 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?facid='.
$object->id, $langs->trans(
'ClassifyPaid'), $langs->trans(
'ConfirmClassifyPaidPartially',
$object->ref),
'confirm_paid_partially', $formquestion,
"yes", 1, 400, 600);
5052 if ($action ==
'canceled') {
5056 $statusreplacement = 0;
5058 if ($objectidnext) {
5059 $facturereplacement =
new Facture($db);
5060 $facturereplacement->fetch($objectidnext);
5061 $statusreplacement = $facturereplacement->status;
5063 if ($objectidnext && $statusreplacement == 0) {
5064 print
'<div class="error">'.$langs->trans(
"ErrorCantCancelIfReplacementInvoiceNotValidated").
'</div>';
5067 $close[1][
'code'] =
'badcustomer';
5068 $close[2][
'code'] =
'abandon';
5070 $close[1][
'label'] = $langs->trans(
"ConfirmClassifyPaidPartiallyReasonBadCustomerDesc");
5071 $close[2][
'label'] = $langs->trans(
"ConfirmClassifyAbandonReasonOtherDesc");
5073 $close[1][
'reason'] = $form->textwithpicto($langs->transnoentities(
"ConfirmClassifyPaidPartiallyReasonBadCustomer",
$object->ref), $close[1][
'label'], 1);
5074 $close[2][
'reason'] = $form->textwithpicto($langs->transnoentities(
"ConfirmClassifyAbandonReasonOther"), $close[2][
'label'], 1);
5077 $arrayreasons[$close[1][
'code']] = $close[1][
'reason'];
5078 $arrayreasons[$close[2][
'code']] = $close[2][
'reason'];
5081 $formquestion = array(
'text' => $langs->trans(
"ConfirmCancelBillQuestion"), 0 => array(
'type' =>
'radio',
'name' =>
'close_code',
'label' => $langs->trans(
"Reason"),
'values' => $arrayreasons), 1 => array(
'type' =>
'text',
'name' =>
'close_note',
'label' => $langs->trans(
"Comment"),
'value' =>
'',
'morecss' =>
'minwidth300'));
5083 $formconfirm = $form->formconfirm($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, $langs->trans(
'CancelBill'), $langs->trans(
'ConfirmCancelBill',
$object->ref),
'confirm_canceled', $formquestion,
"yes", 1, 270);
5087 if ($action ==
'deletepayment') {
5088 $payment_id =
GETPOST(
'paiement_id');
5089 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'&paiement_id='.$payment_id, $langs->trans(
'DeletePayment'), $langs->trans(
'ConfirmDeletePayment'),
'confirm_delete_paiement',
'',
'no', 1);
5093 if ($action ==
'ask_deleteline') {
5094 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&lineid='.$lineid, $langs->trans(
'DeleteProductLine'), $langs->trans(
'ConfirmDeleteProductLine'),
'confirm_deleteline',
'',
'no', 1);
5098 if ($action ==
'ask_subtotal_deleteline') {
5099 $langs->load(
"subtotals");
5100 $title =
"DeleteSubtotalLine";
5101 $question =
"ConfirmDeleteSubtotalLine";
5102 if (
GETPOST(
'type') ==
'title') {
5103 $formconfirm = array(array(
'type' =>
'checkbox',
'name' =>
'deletecorrespondingsubtotalline',
'label' => $langs->trans(
"DeleteCorrespondingSubtotalLine"),
'value' => 0));
5104 $title =
"DeleteTitleLine";
5105 $question =
"ConfirmDeleteTitleLine";
5107 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&lineid='.$lineid, $langs->trans($title), $langs->trans($question),
'confirm_delete_subtotalline', $formconfirm,
'no', 1);
5111 if ($action ==
'clone') {
5112 $filter =
'(s.client:IN:1,2,3)';
5114 $formquestion = array(
5115 array(
'type' =>
'other',
'name' =>
'socid',
'label' => $langs->trans(
"SelectThirdParty"),
'value' => $form->select_company(
$object->socid,
'socid', $filter, 1)),
5116 array(
'type' =>
'date',
'name' =>
'newdate',
'label' => $langs->trans(
"Date"),
'value' =>
dol_now())
5119 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?facid='.
$object->id, $langs->trans(
'ToClone'), $langs->trans(
'ConfirmCloneInvoice',
$object->ref),
'confirm_clone', $formquestion,
'yes', 1, 250);
5123 if ($action ==
'add_title_line') {
5124 $langs->load(
'subtotals');
5126 $depth_array =
$object->getPossibleLevels($langs);
5128 } elseif ($action ==
'add_subtotal_line') {
5129 $langs->load(
'subtotals');
5131 $titles =
$object->getPossibleTitles();
5135 if ($action ==
"remove_file_comfirm") {
5136 $file =
GETPOST(
'file',
'alpha');
5138 $formconfirm = $form->formconfirm(
5139 $_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&file='.urlencode($file),
5140 $langs->trans(
'DeleteFileHeader'),
5141 $langs->trans(
'DeleteFileText').
"<br><br>".$file,
5150 $parameters = array(
'formConfirm' => $formconfirm,
'lineid' => $lineid,
'remainingtopay' => &$resteapayer);
5151 $reshook = $hookmanager->executeHooks(
'formConfirm', $parameters,
$object, $action);
5152 if (empty($reshook)) {
5153 $formconfirm .= $hookmanager->resPrint;
5154 } elseif ($reshook > 0) {
5155 $formconfirm = $hookmanager->resPrint;
5163 $linkback =
'<a href="'.DOL_URL_ROOT.
'/compta/facture/list.php?restore_lastsearch_values=1'.(!empty($socid) ?
'&socid='.$socid :
'').
'">'.$langs->trans(
"BackToList").
'</a>';
5165 $morehtmlref =
'<div class="refidno">';
5168 $morehtmlref .= $form->editfieldkey(
"Ref",
'ref',
$object->ref,
$object, (
int) $usercancreate,
'string',
'', 0, 1);
5169 $morehtmlref .= $form->editfieldval(
"Ref",
'ref',
$object->ref,
$object, (
int) $usercancreate,
'string',
'',
null,
null,
'', 1);
5170 $morehtmlref .=
'<br>';
5173 $morehtmlref .= $form->editfieldkey(
"RefCustomer",
'ref_client',
$object->ref_customer,
$object, (
int) $usercancreate,
'string',
'', 0, 1);
5174 $morehtmlref .= $form->editfieldval(
"RefCustomer",
'ref_client',
$object->ref_customer,
$object, (
int) $usercancreate,
'string'.(getDolGlobalString(
'THIRDPARTY_REF_INPUT_SIZE') ?
':' .
getDolGlobalString(
'THIRDPARTY_REF_INPUT_SIZE') :
''),
'', null, null,
'', 1);
5176 $morehtmlref .=
'<br>'.$object->thirdparty->getNomUrl(1,
'customer');
5178 $morehtmlref .=
' (<a href="'.DOL_URL_ROOT.
'/compta/facture/list.php?socid='.
$object->thirdparty->id.
'&search_societe='.urlencode(
$object->thirdparty->name).
'">'.$langs->trans(
"OtherBills").
'</a>)';
5181 if (isModEnabled(
'project')) {
5182 $langs->load(
"projects");
5183 $morehtmlref .=
'<br>';
5184 if ($usercancreate) {
5185 $morehtmlref .=
img_picto($langs->trans(
"Project"),
'project',
'class="pictofixedwidth"');
5186 if ($action !=
'classify') {
5187 $morehtmlref .=
'<a class="editfielda" href="'.$_SERVER[
'PHP_SELF'].
'?action=classify&token='.
newToken().
'&id='.
$object->id.
'">'.
img_edit($langs->transnoentitiesnoconv(
'SetProject')).
'</a> ';
5189 $morehtmlref .= $form->form_project($_SERVER[
'PHP_SELF'].
'?id='.
$object->id,
$object->socid, (
string)
$object->fk_project, ($action ==
'classify' ?
'projectid' :
'none'), 0, 0, 0, 1,
'',
'maxwidth300');
5191 if (!empty(
$object->fk_project)) {
5193 $proj->fetch(
$object->fk_project);
5194 $morehtmlref .= $proj->getNomUrl(1);
5196 $morehtmlref .=
'<span class="opacitymedium"> - '.dol_escape_htmltag($proj->title).
'</span>';
5201 $morehtmlref .=
'</div>';
5203 $object->totalpaid = $totalpaid;
5204 $object->totalcreditnotes = $totalcreditnotes;
5205 $object->totaldeposits = $totaldeposits;
5208 dol_banner_tab(
$object,
'ref', $linkback, 1,
'ref',
'ref', $morehtmlref,
'', 0,
'',
'');
5211 $parameters = array();
5213 $reshook = $hookmanager->executeHooks(
'tabContentViewInvoice', $parameters,
$object, $action);
5214 if (empty($reshook)) {
5215 print
'<div class="fichecenter">';
5216 print
'<div class="fichehalfleft">';
5217 print
'<div class="underbanner clearboth"></div>';
5219 print
'<table class="border centpercent tableforfield">';
5222 print
'<tr><td class="fieldname_type">'.$langs->trans(
'Type').
'</td><td class="valuefield fieldname_type">';
5225 print
' '.$object->getSubtypeLabel(
'facture');
5228 $facreplaced =
new Facture($db);
5229 $facreplaced->fetch(
$object->fk_facture_source);
5230 print
' <span class="opacitymediumbycolor paddingleft">'.$langs->transnoentities(
"ReplaceInvoice", $facreplaced->getNomUrl(1,
'', 32)).
'</span>';
5234 $facusing->fetch(
$object->fk_facture_source);
5235 print
' <span class="opacitymediumbycolor paddingleft">'.$langs->transnoentities(
"CorrectInvoice", $facusing->getNomUrl(1,
'', 32)).
'</span>';
5239 $object->getListIdAvoirFromInvoice();
5241 if (!empty(
$object->creditnote_ids)) {
5242 print
' <span class="opacitymediumbycolor paddingleft">'.$langs->transnoentities(
"InvoiceHasAvoir");
5244 foreach (
$object->creditnote_ids as $invoiceid) {
5250 $creditnote =
new Facture($db);
5251 $creditnote->fetch($invoiceid);
5252 print $creditnote->getNomUrl(1,
'', 32);
5256 if ($objectidnext > 0) {
5257 $facthatreplace =
new Facture($db);
5258 $facthatreplace->fetch($objectidnext);
5259 print
' <span class="opacitymediumbycolor paddingleft">'.str_replace(
'{s1}', $facthatreplace->getNomUrl(1), $langs->transnoentities(
"ReplacedByInvoice",
'{s1}')).
'</span>';
5264 $result = $discount->fetch(0,
$object->id);
5266 print
' <span class="opacitymediumbycolor paddingleft">';
5267 $s = $langs->trans(
"CreditNoteConvertedIntoDiscount",
'{s1}',
'{s2}');
5268 $s = str_replace(
'{s1}',
$object->getLibType(0), $s);
5269 $s = str_replace(
'{s2}', $discount->getNomUrl(1,
'discount'), $s);
5271 print
'</span><br>';
5275 if (
$object->fk_fac_rec_source > 0) {
5277 $result = $tmptemplate->fetch(
$object->fk_fac_rec_source);
5279 print
' <span class="opacitymediumbycolor paddingleft">';
5280 $s = $langs->transnoentities(
"GeneratedFromTemplate",
'{s1}');
5281 $s = str_replace(
'{s1}', $tmptemplate->getNomUrl(1,
'', 32), $s);
5285 print
' <span class="opacitymediumbycolor paddingleft">';
5286 print $langs->transnoentities(
"GeneratedFromTemplate", $langs->trans(
"ObjectDeleted"));
5294 $langs->load(
"cashdesk");
5295 print
'<tr><td class="fieldname_type">';
5296 print
'<table class="nobordernopadding centpercent"><tr><td>';
5297 print $form->textwithpicto($langs->trans(
'PointOfSale'), $langs->trans(
'POSInfo'));
5299 if ($action !=
'editposinfo' && $usercancreate) {
5300 print
'<td class="right"><a class="editfielda" href="'.$_SERVER[
"PHP_SELF"].
'?action=editposinfo&token='.
newToken().
'&facid='.
$object->id.
'">'.
img_edit($langs->trans(
'SetPOSInfo'), 1).
'</a></td>';
5302 print
'</tr></table>';
5303 print
'</td><td class="valuefield fieldname_type">';
5304 print
'<form method="POST" action="'.$_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'" name="formposinfo">';
5305 print
'<input type="hidden" name="action" value="setposinfo">';
5306 print
'<input type="hidden" name="token" value="' .
newToken() .
'">';
5307 if ($action ==
'editposinfo') {
5308 print
'<input type="text" class="maxwidth150" name="posmodule" placeholder="'.$langs->trans(
"POSModule").
'" value="'.
$object->module_source.
'"> ';
5309 print
'<input type="text" class="maxwidth100" name="posterminal" placeholder="'.$langs->trans(
"Terminal").
'" value="'.
$object->pos_source.
'">';
5310 print
'<input type="submit" class="button" name="submitposinfo" value="'.$langs->trans(
"Submit").
'">';
5313 print
'<span class="opacitymediumbycolor paddingleft">'.dolPrintHTML(ucfirst(
$object->module_source).
' - '.$langs->transnoentitiesnoconv(
"Terminal").
' '.
$object->pos_source).
'</span>';
5321 print
'<!-- Discounts -->'.
"\n";
5322 print
'<tr><td>'.$langs->trans(
'DiscountStillRemaining').
'</td>';
5326 $backtopage = $_SERVER[
"PHP_SELF"].
'?facid='.
$object->id;
5327 include DOL_DOCUMENT_ROOT.
'/core/tpl/object_discounts.tpl.php';
5332 print
'<table class="nobordernopadding centpercent"><tr><td>';
5333 print $langs->trans(
'DateInvoice');
5335 if ($action !=
'editinvoicedate' &&
$object->status == $object::STATUS_DRAFT && $usercancreate && !
getDolGlobalString(
'FAC_FORCE_DATE_VALIDATION')) {
5336 print
'<td class="right"><a class="editfielda" href="'.$_SERVER[
"PHP_SELF"].
'?action=editinvoicedate&token='.
newToken().
'&facid='.
$object->id.
'">'.
img_edit($langs->trans(
'SetDate'), 1).
'</a></td>';
5338 print
'</tr></table>';
5340 if ($action ==
'editinvoicedate') {
5341 $form->form_date($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id,
$object->date,
'invoicedate');
5343 print
'<span class="valuedate">'.dol_print_date(
$object->date,
'day').
'</span>';
5358 print
'<table class="nobordernopadding centpercent"><tr><td>';
5359 print $langs->trans(
'DatePointOfTax');
5362 print
'<td class="right"><a class="editfielda" href="'.$_SERVER[
"PHP_SELF"].
'?action=editdate_pointoftax&token='.
newToken().
'&facid='.
$object->id.
'">'.
img_edit($langs->trans(
'SetDate'), 1).
'</a></td>';
5364 print
'</tr></table>';
5366 if ($action ==
'editdate_pointoftax' && $editable) {
5367 $form->form_date($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id,
$object->date_pointoftax,
'date_pointoftax');
5369 print
'<span class="valuedate">'.dol_print_date(
$object->date_pointoftax,
'day').
'</span>';
5376 print $form->editfieldkey(
'Source',
'input_reason',
'',
$object, (
int) $usercancreate);
5377 print
'</td><td class="valuefield">';
5378 if ($action ==
'editinput_reason') {
5379 $form->formInputReason($_SERVER[
'PHP_SELF'].
'?id='.
$object->id, (
string)
$object->demand_reason_id,
'input_reason_id', 1);
5381 $form->formInputReason($_SERVER[
'PHP_SELF'].
'?id='.
$object->id, (
string)
$object->demand_reason_id,
'none');
5387 print
'<table class="nobordernopadding centpercent"><tr><td>';
5388 print $langs->trans(
'PaymentConditionsShort');
5391 print
'<td class="right"><a class="editfielda" href="'.$_SERVER[
"PHP_SELF"].
'?action=editconditions&token='.
newToken().
'&facid='.
$object->id.
'">'.
img_edit($langs->trans(
'SetConditions'), 1).
'</a></td>';
5393 print
'</tr></table>';
5396 if ($action ==
'editconditions') {
5397 $form->form_conditions_reglement($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, (
string)
$object->cond_reglement_id,
'cond_reglement_id');
5399 $form->form_conditions_reglement($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, (
string)
$object->cond_reglement_id,
'none');
5408 print
'<table class="nobordernopadding centpercent"><tr><td>';
5409 print $langs->trans(
'DateMaxPayment');
5412 print
'<td class="right"><a class="editfielda" href="'.$_SERVER[
"PHP_SELF"].
'?action=editpaymentterm&token='.
newToken().
'&facid='.
$object->id.
'">'.
img_edit($langs->trans(
'SetDate'), 1).
'</a></td>';
5414 print
'</tr></table>';
5417 if ($action ==
'editpaymentterm') {
5418 $form->form_date($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id,
$object->date_lim_reglement,
'paymentterm');
5420 print
'<span class="valuedate">'.dol_print_date(
$object->date_lim_reglement,
'day').
'</span>';
5432 print
'<table class="nobordernopadding centpercent"><tr><td>';
5433 print $langs->trans(
'PaymentMode');
5435 if ($action !=
'editmode' && $usercancreate) {
5436 print
'<td class="right"><a class="editfielda" href="'.$_SERVER[
"PHP_SELF"].
'?action=editmode&token='.
newToken().
'&facid='.
$object->id.
'">'.
img_edit($langs->trans(
'SetMode'), 1).
'</a></td>';
5438 print
'</tr></table>';
5440 if ($action ==
'editmode') {
5441 $form->form_modes_reglement($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, (
string)
$object->mode_reglement_id,
'mode_reglement_id',
'CRDT', 1, 1);
5443 $form->form_modes_reglement($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, (
string)
$object->mode_reglement_id,
'none',
'CRDT');
5448 if (isModEnabled(
"bank")) {
5449 print
'<tr><td class="nowrap">';
5450 print
'<table class="nobordernopadding centpercent"><tr><td class="nowrap">';
5451 print $langs->trans(
'BankAccount');
5453 if (($action !=
'editbankaccount') && $usercancreate) {
5454 print
'<td class="right"><a class="editfielda" href="'.$_SERVER[
"PHP_SELF"].
'?action=editbankaccount&token='.
newToken().
'&id='.
$object->id.
'">'.
img_edit($langs->trans(
'SetBankAccount'), 1).
'</a></td>';
5456 print
'</tr></table>';
5458 if ($action ==
'editbankaccount') {
5459 $form->formSelectAccount($_SERVER[
'PHP_SELF'].
'?id='.
$object->id, (
string)
$object->fk_account,
'fk_account', 1);
5461 $form->formSelectAccount($_SERVER[
'PHP_SELF'].
'?id='.
$object->id, (
string)
$object->fk_account,
'none');
5468 if (isModEnabled(
'incoterm')) {
5470 print
'<table class="nobordernopadding centpercent"><tr><td>';
5471 print $langs->trans(
'IncotermLabel');
5472 print
'<td><td class="right">';
5473 if ($usercancreate) {
5474 print
'<a class="editfielda" href="'.DOL_URL_ROOT.
'/compta/facture/card.php?facid='.
$object->id.
'&action=editincoterm&token='.
newToken().
'">'.
img_edit().
'</a>';
5478 print
'</td></tr></table>';
5481 if ($action !=
'editincoterm') {
5482 print $form->textwithpicto(
$object->display_incoterms(),
$object->label_incoterms, 1);
5484 print $form->select_incoterms((!empty(
$object->fk_incoterms) ?
$object->fk_incoterms :
''), (!empty(
$object->location_incoterms) ?
$object->location_incoterms :
''), $_SERVER[
'PHP_SELF'].
'?id='.
$object->id);
5490 if (isModEnabled(
'category')) {
5492 print
'<table class="nobordernopadding centpercent"><tr><td>';
5493 print $langs->trans(
"Categories");
5494 print
'<td><td class="right">';
5495 if ($usercancreate) {
5496 print
'<a class="editfielda" href="'.DOL_URL_ROOT.
'/compta/facture/card.php?facid='.
$object->id.
'&action=edittags&token='.
newToken().
'">'.
img_edit().
'</a>';
5500 print
'</td></tr></table>';
5503 if ($action ==
'edittags') {
5504 print
'<form method="POST" action="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'">';
5505 print
'<input type="hidden" name="action" value="settags">';
5506 print
'<input type="hidden" name="token" value="'.newToken().
'">';
5507 print $form->selectCategories(Categorie::TYPE_INVOICE,
'categories',
$object);
5508 print
'<input type="submit" class="button valignmiddle smallpaddingimp" value="'.$langs->trans(
"Modify").
'">';
5511 print $form->showCategories(
$object->id, Categorie::TYPE_INVOICE, 1);
5516 $displayWarranty =
false;
5519 $displayWarranty =
true;
5520 if (!in_array(
$object->type, $retainedWarrantyInvoiceAvailableType) && empty(
$object->retained_warranty)) {
5521 $displayWarranty =
false;
5524 if ($displayWarranty) {
5526 print
'<tr class="retained-warranty-lines" ><td>';
5527 print
'<table id="retained-warranty-table" class="nobordernopadding centpercent"><tr><td>';
5528 print $langs->trans(
'RetainedWarranty');
5531 print
'<td align="right"><a class="editfielda" href="'.$_SERVER[
"PHP_SELF"].
'?action=editretainedwarranty&token='.
newToken().
'&facid='.
$object->id.
'">'.
img_edit($langs->trans(
'setRetainedWarranty'), 1).
'</a></td>';
5534 print
'</tr></table>';
5537 print
'<form id="retained-warranty-form" method="POST" action="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'">';
5538 print
'<input type="hidden" name="action" value="setretainedwarranty">';
5539 print
'<input type="hidden" name="token" value="'.newToken().
'">';
5540 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
5541 print
'<input name="retained_warranty" type="number" step="0.01" min="0" max="100" value="'.$object->retained_warranty.
'" >';
5542 print
'<input type="submit" class="button valignmiddle smallpaddingimp" value="'.$langs->trans(
"Modify").
'">';
5550 print
'<tr class="retained-warranty-lines" ><td>';
5551 print
'<table id="retained-warranty-cond-reglement-table" class="nobordernopadding" width="100%"><tr><td>';
5552 print $langs->trans(
'PaymentConditionsShortRetainedWarranty');
5554 if ($action !=
'editretainedwarrantypaymentterms' && $user->hasRight(
'facture',
'creer') &&
$object->status ==
Facture::STATUS_DRAFT) {
5555 print
'<td align="right"><a class="editfielda" href="'.$_SERVER[
"PHP_SELF"].
'?action=editretainedwarrantypaymentterms&token='.
newToken().
'&facid='.
$object->id.
'">'.
img_edit($langs->trans(
'setPaymentConditionsShortRetainedWarranty'), 1).
'</a></td>';
5558 print
'</tr></table>';
5560 $defaultDate = !empty(
$object->retained_warranty_date_limit) ?
$object->retained_warranty_date_limit : strtotime(
'-1 years',
$object->date_lim_reglement);
5561 if (
$object->date > $defaultDate) {
5567 print
'<form method="POST" action="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'">';
5568 print
'<input type="hidden" name="action" value="setretainedwarrantyconditions">';
5569 print
'<input type="hidden" name="token" value="'.newToken().
'">';
5570 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
5571 $retained_warranty_fk_cond_reglement =
GETPOSTINT(
'retained_warranty_fk_cond_reglement');
5572 $retained_warranty_fk_cond_reglement = !empty($retained_warranty_fk_cond_reglement) ? $retained_warranty_fk_cond_reglement :
$object->retained_warranty_fk_cond_reglement;
5573 $retained_warranty_fk_cond_reglement = !empty($retained_warranty_fk_cond_reglement) ? $retained_warranty_fk_cond_reglement :
getDolGlobalString(
'INVOICE_SITUATION_DEFAULT_RETAINED_WARRANTY_COND_ID');
5574 print $form->getSelectConditionsPaiements($retained_warranty_fk_cond_reglement,
'retained_warranty_fk_cond_reglement', -1, 1);
5575 print
'<input type="submit" class="button valignmiddle" value="'.$langs->trans(
"Modify").
'">';
5578 $form->form_conditions_reglement($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, (
string)
$object->retained_warranty_fk_cond_reglement,
'none');
5579 if (!$displayWarranty) {
5580 print
img_picto($langs->trans(
'RetainedWarrantyNeed100Percent'),
'warning.png',
'class="pictowarning valignmiddle" ');
5586 print
'<tr class="retained-warranty-lines" ><td>';
5587 print
'<table id="retained-warranty-date-limit-table" class="nobordernopadding" width="100%"><tr><td>';
5588 print $langs->trans(
'RetainedWarrantyDateLimit');
5591 print
'<td align="right"><a class="editfielda" href="'.$_SERVER[
"PHP_SELF"].
'?action=editretainedwarrantydatelimit&token='.
newToken().
'&facid='.
$object->id.
'">'.
img_edit($langs->trans(
'setRetainedWarrantyDateLimit'), 1).
'</a></td>';
5594 print
'</tr></table>';
5596 $defaultDate = !empty(
$object->retained_warranty_date_limit) ?
$object->retained_warranty_date_limit : strtotime(
'-1 years',
$object->date_lim_reglement);
5597 if (
$object->date > $defaultDate) {
5603 print
'<form method="POST" action="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'">';
5604 print
'<input type="hidden" name="action" value="setretainedwarrantydatelimit">';
5605 print
'<input type="hidden" name="token" value="'.newToken().
'">';
5606 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
5607 print
'<input name="retained_warranty_date_limit" type="date" step="1" min="'.dol_print_date(
$object->date,
'%Y-%m-%d').
'" value="'.
dol_print_date($defaultDate,
'%Y-%m-%d').
'" >';
5608 print
'<input type="submit" class="button valignmiddle" value="'.$langs->trans(
"Modify").
'">';
5620 include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_view.tpl.php';
5625 print
'<div class="fichehalfright">';
5627 print
'<!-- amounts -->'.
"\n";
5628 print
'<div class="underbanner clearboth"></div>'.
"\n";
5630 print
'<table class="border tableforfield centpercent">';
5632 include DOL_DOCUMENT_ROOT.
'/core/tpl/object_currency_amount.tpl.php';
5640 print
'<td class="titlefieldmiddle">' . $langs->trans(
'AmountHT') .
'</td>';
5641 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->total_ht, 0, $langs, 0, -1, -1,
$conf->currency) .
'</td>';
5642 if (isModEnabled(
"multicurrency") && (
$object->multicurrency_code &&
$object->multicurrency_code !=
$conf->currency)) {
5644 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->multicurrency_total_ht, 0, $langs, 0, -1, -1,
$object->multicurrency_code) .
'</td>';
5650 print
'<td>' . $langs->trans(
'AmountVAT') .
'</td>';
5651 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->total_tva, 0, $langs, 0, -1, -1,
$conf->currency) .
'</td>';
5652 if (isModEnabled(
"multicurrency") && (
$object->multicurrency_code &&
$object->multicurrency_code !=
$conf->currency)) {
5654 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->multicurrency_total_tva, 0, $langs, 0, -1, -1,
$object->multicurrency_code) .
'</td>';
5659 if (($mysoc->localtax1_assuj ==
"1" && $mysoc->useLocalTax(1)) ||
$object->total_localtax1 != 0) {
5661 print
'<td class="titlefieldmiddle">' . $langs->transcountry(
"AmountLT1", $mysoc->country_code) .
'</td>';
5662 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->total_localtax1, 0, $langs, 0, -1, -1,
$conf->currency) .
'</td>';
5663 if (isModEnabled(
"multicurrency") && (
$object->multicurrency_code &&
$object->multicurrency_code !=
$conf->currency)) {
5666 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->multicurrency_total_localtax1, 0, $langs, 0, -1, -1,
$object->multicurrency_code) .
'</td>';
5671 if (($mysoc->localtax2_assuj ==
"1" && $mysoc->useLocalTax(2)) ||
$object->total_localtax2 != 0) {
5673 print
'<td>' . $langs->transcountry(
"AmountLT2", $mysoc->country_code) .
'</td>';
5674 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->total_localtax2, 0, $langs, 0, -1, -1,
$conf->currency) .
'</td>';
5675 if (isModEnabled(
"multicurrency") && (
$object->multicurrency_code &&
$object->multicurrency_code !=
$conf->currency)) {
5678 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->multicurrency_total_localtax2, 0, $langs, 0, -1, -1,
$object->multicurrency_code) .
'</td>';
5684 if ($selleruserevenustamp) {
5685 print
'<tr><td class="titlefieldmiddle">';
5686 print
'<table class="nobordernopadding centpercent"><tr><td>';
5687 print $langs->trans(
'RevenueStamp');
5689 if ($action !=
'editrevenuestamp' &&
$object->status == $object::STATUS_DRAFT && $usercancreate) {
5690 print
'<td class="right"><a class="editfielda" href="'.$_SERVER[
"PHP_SELF"].
'?action=editrevenuestamp&token='.
newToken().
'&facid='.
$object->id.
'">'.
img_edit($langs->trans(
'SetRevenuStamp'), 1).
'</a></td>';
5692 print
'</tr></table>';
5693 print
'</td><td class="nowrap amountcard right">';
5694 if ($action ==
'editrevenuestamp') {
5695 print
'<form action="'.$_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'" method="post">';
5696 print
'<input type="hidden" name="token" value="'.newToken().
'">';
5697 print
'<input type="hidden" name="action" value="setrevenuestamp">';
5698 print
'<input type="hidden" name="revenuestamp" id="revenuestamp_val" value="'.price2num(
$object->revenuestamp).
'">';
5699 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
5700 print $formother->select_revenue_stamp(
'',
'revenuestamp_type', $mysoc->country_code);
5701 print
' → <span id="revenuestamp_span"></span>';
5702 print
' <input type="submit" class="button buttongen button-save small" value="'.$langs->trans(
'Modify').
'">';
5705 $(document).ready(function(){
5706 js_recalculate_revenuestamp();
5707 $('select[name=revenuestamp_type]').on('change',function(){
5708 js_recalculate_revenuestamp();
5711 function js_recalculate_revenuestamp(){
5712 var valselected = $('select[name=revenuestamp_type]').val();
5713 console.log('Calculate revenue stamp from '+valselected);
5715 if (valselected.indexOf('%') == -1)
5717 revenue = valselected;
5721 var revenue_type = parseFloat(valselected);
5722 var amount_net = ".round(
$object->total_ht, 2).
";
5723 revenue = revenue_type * amount_net / 100;
5724 revenue = revenue.toFixed(2);
5726 $('#revenuestamp_val').val(revenue);
5727 $('#revenuestamp_span').html(revenue);
5738 print
'<td>' . $langs->trans(
'AmountTTC') .
'</td>';
5739 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->total_ttc, 0, $langs, 0, -1, -1,
$conf->currency) .
'</td>';
5740 if (isModEnabled(
"multicurrency") && (
$object->multicurrency_code &&
$object->multicurrency_code !=
$conf->currency)) {
5742 print
'<td class="nowrap amountcard right">' .
price($sign *
$object->multicurrency_total_ttc, 0, $langs, 0, -1, -1,
$object->multicurrency_code) .
'</td>';
5750 if (isModEnabled(
'project')) {
5753 if (isModEnabled(
"bank")) {
5757 if ($mysoc->localtax1_assuj ==
"1" ||
$object->total_localtax1 != 0) {
5760 if ($mysoc->localtax2_assuj ==
"1" ||
$object->total_localtax2 != 0) {
5763 if ($selleruserevenustamp) {
5766 if (isModEnabled(
'multicurrency')) {
5769 if (isModEnabled(
'incoterm')) {
5773 $total_prev_ht = $total_prev_ttc = 0;
5774 $total_global_ht = $total_global_ttc = 0;
5778 print
'<!-- List of situation invoices -->';
5779 print
'<div class="div-table-responsive-no-min">';
5780 print
'<table class="noborder paymenttable centpercent situationstable">';
5782 print
'<tr class="liste_titre">';
5783 print
'<td>'.$langs->trans(
'ListOfSituationInvoices').
'</td>';
5785 print
'<td class="center">'.$langs->trans(
'Situation').
'</td>';
5787 if (isModEnabled(
"bank")) {
5788 print
'<td class="right"></td>';
5790 print
'<td class="right">'.$langs->trans(
'AmountHT').
'</td>';
5791 print
'<td class="right">'.$langs->trans(
'AmountTTC').
'</td>';
5792 print
'<td width="18"> </td>';
5795 if (count(
$object->tab_previous_situation_invoice) > 0) {
5798 $current_situation_counter = array();
5799 foreach (
$object->tab_previous_situation_invoice as $prev_invoice) {
5800 $tmptotalallpayments = $prev_invoice->getSommePaiement(0);
5801 $tmptotalallpayments += $prev_invoice->getSumDepositsUsed(0);
5802 $tmptotalallpayments += $prev_invoice->getSumCreditNotesUsed(0);
5804 $total_prev_ht += $prev_invoice->total_ht;
5805 $total_prev_ttc += $prev_invoice->total_ttc;
5807 $current_situation_counter[] = (($prev_invoice->type ==
Facture::TYPE_CREDIT_NOTE) ? -1 : 1) * $prev_invoice->situation_counter;
5808 print
'<tr class="oddeven">';
5809 print
'<td>'.$prev_invoice->getNomUrl(1).
'</td>';
5811 print
'<td align="center" >'.(($prev_invoice->type ==
Facture::TYPE_CREDIT_NOTE) ? $langs->trans(
'situationInvoiceShortcode_AS') : $langs->trans(
'situationInvoiceShortcode_S')).$prev_invoice->situation_counter.
'</td>';
5812 if (isModEnabled(
"bank")) {
5813 print
'<td class="right"></td>';
5815 print
'<td class="right"><span class="amount">'.price($prev_invoice->total_ht).
'</span></td>';
5816 print
'<td class="right"><span class="amount">'.price($prev_invoice->total_ttc).
'</span></td>';
5817 print
'<td class="right">'.$prev_invoice->getLibStatut(3, $tmptotalallpayments).
'</td>';
5822 $totalallpayments =
$object->getSommePaiement(0);
5823 $totalallpayments +=
$object->getSumCreditNotesUsed(0);
5824 $totalallpayments +=
$object->getSumDepositsUsed(0);
5826 $total_global_ht += $total_prev_ht;
5827 $total_global_ttc += $total_prev_ttc;
5828 $total_global_ht +=
$object->total_ht;
5829 $total_global_ttc +=
$object->total_ttc;
5833 print
'<tr class="oddeven">';
5834 print
'<td>'.$object->getNomUrl(1).
'</td>';
5836 print
'<td class="center">'.(($object->type ==
Facture::TYPE_CREDIT_NOTE) ? $langs->trans(
'situationInvoiceShortcode_AS') : $langs->trans(
'situationInvoiceShortcode_S')).
$object->situation_counter.
'</td>';
5837 if (isModEnabled(
"bank")) {
5838 print
'<td class="right"></td>';
5840 print
'<td class="right"><span class="amount">'.price(
$object->total_ht).
'</span></td>';
5841 print
'<td class="right"><span class="amount">'.price(
$object->total_ttc).
'</span></td>';
5842 print
'<td class="right">'.$object->getLibStatut(3, $totalallpayments).
'</td>';
5846 print
'<tr class="oddeven">';
5847 print
'<td colspan="2" class="left"><b>'.$langs->trans(
'CurrentSituationTotal').
'</b></td>';
5850 foreach ($current_situation_counter as $sit) {
5851 $curSign = $sit > 0 ?
'+' :
'-';
5852 $curType = $sit > 0 ? $langs->trans(
'situationInvoiceShortcode_S') : $langs->trans(
'situationInvoiceShortcode_AS');
5854 print
' '.$curSign.
' ';
5856 print $curType.abs($sit);
5860 if (isModEnabled(
"bank")) {
5863 print
'<td class="right"><b>'.price($total_global_ht).
'</b></td>';
5864 print
'<td class="right"><b>'.price($total_global_ttc).
'</b></td>';
5865 print
'<td width="18"> </td>';
5869 if (count(
$object->tab_next_situation_invoice) > 0) {
5881 $total_next_ht = $total_next_ttc = 0;
5883 foreach (
$object->tab_next_situation_invoice as $next_invoice) {
5884 $totalpaid = $next_invoice->getSommePaiement(0);
5885 $totalcreditnotes = $next_invoice->getSumCreditNotesUsed(0);
5886 $totaldeposits = $next_invoice->getSumDepositsUsed(0);
5887 $total_next_ht += $next_invoice->total_ht;
5888 $total_next_ttc += $next_invoice->total_ttc;
5890 print
'<tr class="oddeven">';
5891 print
'<td>'.$next_invoice->getNomUrl(1).
'</td>';
5893 print
'<td class="center">'.(($next_invoice->type ==
Facture::TYPE_CREDIT_NOTE) ? $langs->trans(
'situationInvoiceShortcode_AS') : $langs->trans(
'situationInvoiceShortcode_S')).$next_invoice->situation_counter.
'</td>';
5894 if (isModEnabled(
"bank")) {
5895 print
'<td class="right"></td>';
5897 print
'<td class="right"><span class="amount">'.price($next_invoice->total_ht).
'</span></td>';
5898 print
'<td class="right"><span class="amount">'.price($next_invoice->total_ttc).
'</span></td>';
5899 print
'<td class="right">'.$next_invoice->getLibStatut(3, $totalpaid + $totalcreditnotes + $totaldeposits).
'</td>';
5903 $total_global_ht += $total_next_ht;
5904 $total_global_ttc += $total_next_ttc;
5906 print
'<tr class="oddeven">';
5907 print
'<td colspan="3" class="right"></td>';
5908 if (isModEnabled(
"bank")) {
5909 print
'<td class="right"></td>';
5911 print
'<td class="right"><b>'.price($total_global_ht).
'</b></td>';
5912 print
'<td class="right"><b>'.price($total_global_ttc).
'</b></td>';
5913 print
'<td width="18"> </td>';
5922 if (
$object->type == $object::TYPE_CREDIT_NOTE) {
5928 print
'<!-- List of payments already done -->';
5929 print
'<div class="div-table-responsive-no-min">';
5930 print
'<table class="noborder paymenttable centpercent">';
5932 print
'<tr class="liste_titre">';
5933 print
'<td class="liste_titre">'.($object->type ==
Facture::TYPE_CREDIT_NOTE ? $langs->trans(
"PaymentsBack") : $langs->trans(
'Payments')).
'</td>';
5934 print
'<td class="liste_titre"><span class="hideonsmartphone">'.$langs->trans(
'Date').
'</span></td>';
5935 print
'<td class="liste_titre"><span class="hideonsmartphone">'.$langs->trans(
'Type').
'</span></td>';
5936 if (isModEnabled(
"bank")) {
5937 print
'<td class="liste_titre"><span class="hideonsmartphone">'.$langs->trans(
'BankAccount').
'</span></td>';
5939 print
'<td class="liste_titre right">'.$langs->trans(
'Amount').
'</td>';
5940 print
'<td class="liste_titre" width="18"> </td>';
5944 $sql =
'SELECT p.datep as dp, p.ref, p.num_paiement as num_payment, p.rowid, p.fk_bank,';
5945 $sql .=
' c.code as payment_code, c.libelle as payment_label,';
5946 $sql .=
' pf.amount,';
5947 $sql .=
' ba.rowid as baid, ba.ref as baref, ba.label, ba.number as banumber, ba.account_number, ba.fk_accountancy_journal, ba.currency_code as bacurrency_code';
5948 $sql .=
' FROM '.MAIN_DB_PREFIX.
'paiement_facture as pf, '.MAIN_DB_PREFIX.
'paiement as p';
5949 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_paiement as c ON p.fk_paiement = c.id';
5950 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'bank as b ON p.fk_bank = b.rowid';
5951 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'bank_account as ba ON b.fk_account = ba.rowid';
5952 $sql .=
' WHERE pf.fk_facture = '.((int)
$object->id).
' AND pf.fk_paiement = p.rowid';
5953 $sql .=
' AND p.entity IN ('.getEntity(
'invoice').
')';
5954 $sql .=
' ORDER BY p.datep, p.tms';
5956 $result = $db->query($sql);
5958 $num = $db->num_rows($result);
5963 $objp = $db->fetch_object($result);
5965 $paymentstatic->id = $objp->rowid;
5966 $paymentstatic->datepaye = $db->jdate($objp->dp);
5967 $paymentstatic->ref = $objp->ref;
5968 $paymentstatic->num_payment = $objp->num_payment;
5969 $paymentstatic->paiementcode = $objp->payment_code;
5971 print
'<tr class="oddeven"><td class="nowraponall">';
5972 print $paymentstatic->getNomUrl(1);
5975 $dateofpayment = $db->jdate($objp->dp);
5977 if ($tmparray[
'seconds'] == 0 && $tmparray[
'minutes'] == 0 && ($tmparray[
'hours'] == 0 || $tmparray[
'hours'] == 12)) {
5984 $label = ($langs->trans(
"PaymentType".$objp->payment_code) !=
"PaymentType".$objp->payment_code) ? $langs->trans(
"PaymentType".$objp->payment_code) : $objp->payment_label;
5985 print
'<td class="tdoverflowmax80" title="'.dol_escape_htmltag($label.
' '.$objp->num_payment).
'">'.
dol_escape_htmltag($label.
' '.$objp->num_payment).
'</td>';
5986 if (isModEnabled(
"bank")) {
5987 $bankaccountstatic->id = $objp->baid;
5988 $bankaccountstatic->ref = $objp->baref;
5989 $bankaccountstatic->label = $objp->baref;
5990 $bankaccountstatic->number = $objp->banumber;
5991 $bankaccountstatic->currency_code = $objp->bacurrency_code;
5993 if (isModEnabled(
'accounting')) {
5994 $bankaccountstatic->account_number = $objp->account_number;
5997 $accountingjournal->fetch($objp->fk_accountancy_journal);
5998 $bankaccountstatic->accountancy_journal = $accountingjournal->getNomUrl(0, 1, 1,
'', 1);
6001 print
'<td class="nowraponall">';
6002 if ($bankaccountstatic->id) {
6003 print $bankaccountstatic->getNomUrl(1,
'transactions');
6007 print
'<td class="right"><span class="amount">'.price($sign * $objp->amount).
'</span></td>';
6008 print
'<td class="center">';
6011 $paiement->fetch($objp->rowid);
6013 print
'<a href="'.$_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'&action=deletepayment&token='.
newToken().
'&paiement_id='.$objp->rowid.
'">';
6030 print
'<tr><td colspan="'.$nbcols.
'" class="right">';
6031 print
'<span class="opacitymedium">';
6033 print $langs->trans(
'AlreadyPaidNoCreditNotesNoDeposits');
6035 print $langs->trans(
'AlreadyPaid');
6037 print
'</span></td><td class="right'.(($totalpaid > 0) ?
' amountalreadypaid' :
'').
'">'.
price($totalpaid).
'</td><td> </td></tr>';
6039 $resteapayeraffiche = $resteapayer;
6040 $cssforamountpaymentcomplete =
'amountpaymentcomplete';
6043 $creditnoteamount = 0;
6045 $sql =
"SELECT re.rowid, re.amount_ht, re.amount_tva, re.amount_ttc,";
6046 $sql .=
" re.description, re.fk_facture_source";
6047 $sql .=
" FROM ".MAIN_DB_PREFIX.
"societe_remise_except as re";
6048 $sql .=
" WHERE fk_facture = ".((int)
$object->id);
6049 $resql = $db->query($sql);
6051 $num = $db->num_rows($resql);
6055 $obj = $db->fetch_object($resql);
6056 $invoice->fetch($obj->fk_facture_source);
6057 print
'<tr><td colspan="'.$nbcols.
'" class="right">';
6058 print
'<span class="opacitymedium">';
6060 print $langs->trans(
"CreditNote").
' ';
6063 print $langs->trans(
"Deposit").
' ';
6065 print $invoice->getNomUrl(0);
6068 print
'<td class="right"><span class="amount">'.price($obj->amount_ttc).
'</span></td>';
6069 print
'<td class="right">';
6070 print
'<a href="'.$_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&action=unlinkdiscount&token='.
newToken().
'&discountid='.$obj->rowid.
'">';
6071 print
img_picto($langs->transnoentitiesnoconv(
"RemoveDiscount"),
'unlink');
6076 $creditnoteamount += $obj->amount_ttc;
6079 $depositamount += $obj->amount_ttc;
6088 print
'<tr><td colspan="'.$nbcols.
'" class="nowrap right">';
6089 print
'<span class="opacitymedium">';
6090 print $form->textwithpicto($langs->trans(
"Discount"), $langs->trans(
"HelpEscompte"), - 1);
6092 print
'</td><td class="right"><span class="amount">'.price(
price2num(
$object->total_ttc - $creditnoteamount - $depositamount - $totalpaid,
'MT')).
'</span></td><td> </td></tr>';
6093 $resteapayeraffiche = 0;
6094 $cssforamountpaymentcomplete =
'amountpaymentneutral';
6098 print
'<tr><td colspan="'.$nbcols.
'" class="nowrap right">';
6099 print
'<span class="opacitymedium">';
6100 print $form->textwithpicto($langs->trans(
"Abandoned"), $langs->trans(
"HelpAbandonBadCustomer"), - 1);
6102 print
'</td><td class="right">'.price(
price2num(
$object->total_ttc - $creditnoteamount - $depositamount - $totalpaid,
'MT')).
'</td><td> </td></tr>';
6104 $cssforamountpaymentcomplete =
'amountpaymentneutral';
6108 print
'<tr><td colspan="'.$nbcols.
'" class="nowrap right">';
6109 print
'<span class="opacitymedium">';
6110 print $form->textwithpicto($langs->trans(
"ProductReturned"), $langs->trans(
"HelpAbandonProductReturned"), - 1);
6112 print
'</td><td class="right"><span class="amount">'.price(
price2num(
$object->total_ttc - $creditnoteamount - $depositamount - $totalpaid,
'MT')).
'</span></td><td> </td></tr>';
6113 $resteapayeraffiche = 0;
6114 $cssforamountpaymentcomplete =
'amountpaymentneutral';
6118 print
'<tr><td colspan="'.$nbcols.
'" class="nowrap right">';
6119 $text = $langs->trans(
"HelpAbandonOther");
6121 $text .=
'<br><br><b>'.$langs->trans(
"Reason").
'</b>:'.
$object->close_note;
6123 print
'<span class="opacitymedium">';
6125 print $form->textwithpicto($langs->trans(
"Abandoned"), $text, - 1);
6127 print
'</td><td class="right"><span class="amount">'.price(
price2num(
$object->total_ttc - $creditnoteamount - $depositamount - $totalpaid,
'MT')).
'</span></td><td> </td></tr>';
6128 $resteapayeraffiche = 0;
6129 $cssforamountpaymentcomplete =
'amountpaymentneutral';
6133 print
'<tr><td colspan="'.$nbcols.
'" class="right">';
6134 print
'<span class="opacitymedium">';
6135 print $langs->trans(
"Billed");
6136 print
'</td><td class="right">'.price(
$object->total_ttc).
'</td><td> </td></tr>';
6138 print
'<tr><td colspan="'.$nbcols.
'" class="right">';
6139 print
'<span class="opacitymedium">';
6140 print $langs->trans(
'RemainderToPay');
6141 if ($resteapayeraffiche < 0) {
6142 print
' ('.$langs->trans(
'NegativeIfExcessReceived').
')';
6146 print
'<td class="right'.($resteapayeraffiche ?
' amountremaintopay' : (
' '.$cssforamountpaymentcomplete)).
'">'.
price($resteapayeraffiche).
'</td><td> </td></tr>';
6150 print
'<tr><td colspan="'.$nbcols.
'" class="right">';
6151 print
'<span class="opacitymedium">';
6152 print $langs->trans(
'RemainderToPayMulticurrency');
6153 if ($resteapayeraffiche < 0) {
6154 print
' ('.$langs->trans(
'NegativeIfExcessReceived').
')';
6158 print
'<td class="right'.($resteapayeraffiche ?
' amountremaintopay' : (
' '.$cssforamountpaymentcomplete)).
'">';
6160 print
price(
price2num(
$object->multicurrency_tx * $resteapayeraffiche,
'MT'), 1, $langs, 1, -1, -1, (empty(
$object->multicurrency_code) ?
$conf->currency :
$object->multicurrency_code)).
'</td><td> </td></tr>';
6164 if (!empty(
$object->situation_final) && !empty(
$object->retained_warranty) && $displayWarranty) {
6166 if (
$object->isSituationInvoice()) {
6167 $retainedWarranty = $total_global_ttc *
$object->retained_warranty / 100;
6170 $retainedWarranty =
$object->total_ttc *
$object->retained_warranty / 100;
6173 $billedWithRetainedWarranty =
$object->total_ttc - $retainedWarranty;
6175 print
'<tr><td colspan="'.$nbcols.
'" align="right">'.$langs->trans(
"ToPayOn",
dol_print_date(
$object->date_lim_reglement,
'day')).
' :</td><td align="right">'.
price($billedWithRetainedWarranty).
'</td><td> </td></tr>';
6178 print
'<tr><td colspan="'.$nbcols.
'" align="right">';
6179 print $langs->trans(
"RetainedWarranty").
' ('.
$object->retained_warranty.
'%)';
6180 print !empty(
$object->retained_warranty_date_limit) ?
' '.$langs->trans(
"ToPayOn",
dol_print_date(
$object->retained_warranty_date_limit,
'day')) :
'';
6181 print
' :</td><td align="right">'.price($retainedWarranty).
'</td><td> </td></tr>';
6184 $resteapayeraffiche = $resteapayer;
6185 $cssforamountpaymentcomplete =
'amountpaymentneutral';
6188 print
'<tr><td colspan="'.$nbcols.
'" class="right">';
6189 print
'<span class="opacitymedium">'.$langs->trans(
'AlreadyPaidBack').
'</span>';
6190 print
'</td><td class="right"><span class="amount">'.price($sign * $totalpaid).
'</span></td><td> </td></tr>';
6193 print
'<tr><td colspan="'.$nbcols.
'" class="right"><span class="opacitymedium">'.$langs->trans(
"Billed").
'</span></td><td class="right">'.
price($sign *
$object->total_ttc).
'</td><td> </td></tr>';
6196 print
'<tr><td colspan="'.$nbcols.
'" class="right">';
6197 print
'<span class="opacitymedium">'.$langs->trans(
'RemainderToPayBack');
6198 if ($resteapayeraffiche > 0) {
6199 print
' ('.$langs->trans(
'NegativeIfExcessRefunded').
')';
6201 print
'</span></td>';
6202 print
'<td class="right'.($resteapayeraffiche ?
' amountremaintopayback' : (
' '.$cssforamountpaymentcomplete)).
'">'.
price($sign * $resteapayeraffiche).
'</td>';
6203 print
'<td class="nowrap"> </td></tr>';
6207 print
'<tr><td colspan="'.$nbcols.
'" class="right">';
6208 print
'<span class="opacitymedium">'.$langs->trans(
'RemainderToPayBackMulticurrency');
6209 if ($resteapayeraffiche > 0) {
6210 print
' ('.$langs->trans(
'NegativeIfExcessRefunded').
')';
6214 print
'<td class="right'.($resteapayeraffiche ?
' amountremaintopayback' : (
' '.$cssforamountpaymentcomplete)).
'">'.(!empty(
$object->multicurrency_code) ?
$object->multicurrency_code :
$conf->currency).
' '.
price(
price2num($sign *
$object->multicurrency_tx * $resteapayeraffiche,
'MT')).
'</td><td> </td></tr>';
6227 if (isModEnabled(
'margin')) {
6228 $formmargin->displayMarginInfos(
$object);
6234 print
'<div class="clearboth"></div><br>';
6237 $blocname =
'contacts';
6238 $title = $langs->trans(
'ContactsAddresses');
6239 include DOL_DOCUMENT_ROOT.
'/core/tpl/bloc_showhide.tpl.php';
6243 $blocname =
'notes';
6244 $title = $langs->trans(
'Notes');
6245 include DOL_DOCUMENT_ROOT.
'/core/tpl/bloc_showhide.tpl.php';
6249 $result =
$object->getLinesArray();
6253 global $inputalsopricewithtax;
6254 $inputalsopricewithtax = 1;
6259 print
'<!-- Area to change globally the situation percent -->'.
"\n";
6260 print
'<div class="div-table-responsive-no-min">';
6262 print
'<form name="updatealllines" id="updatealllines" action="'.$_SERVER[
'PHP_SELF'].
'?id='.
$object->id.
'#updatealllines" method="POST">';
6263 print
'<input type="hidden" name="token" value="'.newToken().
'" />';
6264 print
'<input type="hidden" name="action" value="updatealllines" />';
6265 print
'<input type="hidden" name="id" value="'.$object->id.
'" />';
6266 print
'<input type="hidden" name="page_y" value="" />';
6267 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
6269 print
'<table id="tablelines_all_progress" class="noborder noshadow centpercent">';
6271 print
'<tr class="liste_titre nodrag nodrop">';
6275 print
'<td align="center" width="5"> </td>';
6277 print
'<td class="minwidth500imp">'.$langs->trans(
'ModifyAllLines').
'</td>';
6278 print
'<td class="right">'.$langs->trans(
'Progress').
'</td>';
6279 print
'<td> </td>';
6282 print
'<tr class="nodrag nodrop">';
6285 print
'<td align="center" width="5"> </td>';
6287 print
'<td> </td>';
6288 print
'<td class="nowrap right"><input type="text" size="1" value="" name="all_progress">%</td>';
6289 print
'<td class="right"><input type="submit" class="button reposition small" name="all_percent" value="'.$langs->trans(
"Modify").
'" /></td>';
6300 print
' <form name="addproduct" id="addproduct" action="'.$_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'" method="POST">
6301 <input type="hidden" name="token" value="' .
newToken().
'">
6302 <input type="hidden" name="action" value="' . (($action !=
'editline') ?
'addline' :
'updateline').
'">
6303 <input type="hidden" name="mode" value="">
6304 <input type="hidden" name="page_y" value="">
6305 <input type="hidden" name="id" value="' .
$object->id.
'">
6306 <input type="hidden" name="backtopage" value="'.$backtopage.
'">
6309 if (!empty(
$conf->use_javascript_ajax) &&
$object->status == 0) {
6310 if (isModEnabled(
'subtotals')) {
6311 include DOL_DOCUMENT_ROOT.
'/core/tpl/subtotal_ajaxrow.tpl.php';
6313 include DOL_DOCUMENT_ROOT .
'/core/tpl/ajaxrow.tpl.php';
6317 print
'<div class="div-table-responsive-no-min">';
6318 print
'<table id="tablelines" class="noborder noshadow centpercent nomarginbottom">';
6322 $object->printObjectLines($action, $mysoc, $soc, $lineid, 1);
6326 if (
$object->status == 0 && $usercancreate && $action !=
'valid') {
6327 if ($action !=
'editline' && $action !=
'selectlines') {
6330 $parameters = array();
6331 $reshook = $hookmanager->executeHooks(
'formAddObjectLine', $parameters,
$object, $action);
6335 if (empty($reshook)) {
6336 $object->formAddObjectLine(1, $mysoc, $soc);
6339 $parameters = array();
6340 $reshook = $hookmanager->executeHooks(
'formEditObjectLine', $parameters,
$object, $action);
6354 if ($action !=
'prerelance' && $action !=
'presend' && $action !=
'valid' && $action !=
'editline') {
6355 print
'<div class="tabsAction">';
6357 $parameters = array();
6358 $reshook = $hookmanager->executeHooks(
'addMoreActionsButtons', $parameters,
$object, $action);
6359 if (empty($reshook)) {
6362 'class' =>
'classfortooltip',
6369 $ventilExportCompta =
$object->getVentilExportCompta();
6371 if ($ventilExportCompta == 0) {
6373 if (!$objectidnext &&
$object->is_last_in_cycle()) {
6374 if ($usercanunvalidate) {
6375 unset($params[
'attr'][
'title']);
6376 print
dolGetButtonAction($langs->trans(
'Modify'),
'',
'default', $_SERVER[
'PHP_SELF'] .
'?facid=' .
$object->id .
'&action=modif&token=' .
newToken(),
'',
true, $params);
6378 $params[
'attr'][
'title'] = $langs->trans(
'NotEnoughPermissions');
6379 print
dolGetButtonAction($langs->trans(
'Modify'),
'',
'default', $_SERVER[
'PHP_SELF'] .
'?facid=' .
$object->id .
'&action=modif&token=' .
newToken(),
'',
false, $params);
6381 } elseif (!
$object->is_last_in_cycle()) {
6382 $params[
'attr'][
'title'] = $langs->trans(
'NotLastInCycle');
6383 print
dolGetButtonAction($langs->trans(
'Modify'),
'',
'default',
'#',
'',
false, $params);
6385 $params[
'attr'][
'title'] = $langs->trans(
'DisabledBecauseReplacedInvoice');
6386 print
dolGetButtonAction($langs->trans(
'Modify'),
'',
'default',
'#',
'',
false, $params);
6390 $params[
'attr'][
'title'] = $langs->trans(
'DisabledBecauseDispatchedInBookkeeping');
6391 print
dolGetButtonAction($langs->trans(
'Modify'),
'',
'default',
'#',
'',
false, $params);
6396 $result = $discount->fetch(0,
$object->id);
6404 && ((!
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $usercancreate) || $usercanreopen)) {
6405 if (
$object->close_code !=
'replaced' || (!$objectidnext)) {
6406 unset($params[
'attr'][
'title']);
6407 print
dolGetButtonAction($langs->trans(
'ReOpen'),
'',
'default', $_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=reopen&token='.
newToken(),
'',
true, $params);
6409 $params[
'attr'][
'title'] = $langs->trans(
"DisabledBecauseReplacedInvoice");
6410 print
dolGetButtonAction($langs->trans(
'ReOpen'),
'',
'default',
'#',
'',
false, $params);
6417 $langs->load(
"contracts");
6419 if ($usercancreatecontract) {
6420 print
'<a class="butAction" href="' . DOL_URL_ROOT .
'/contrat/card.php?action=create&origin=' .
$object->element .
'&originid=' .
$object->id .
'&socid=' .
$object->socid .
'">' . $langs->trans(
'AddContract') .
'</a>';
6428 $langs->load(
"subtotals");
6430 $url_button = array();
6432 $url_button[] = array(
6433 'lang' =>
'subtotals',
6435 'perm' => (
bool) $usercancreate,
6436 'label' => $langs->trans(
'AddTitleLine'),
6437 'url' =>
'/compta/facture/card.php?facid='.$object->id.
'&action=add_title_line&token='.
newToken()
6440 $url_button[] = array(
6441 'lang' =>
'subtotals',
6443 'perm' => (
bool) $usercancreate,
6444 'label' => $langs->trans(
'AddSubtotalLine'),
6445 'url' =>
'/compta/facture/card.php?facid='.$object->id.
'&action=add_subtotal_line&token='.
newToken()
6447 print
dolGetButtonAction(
'', $langs->trans(
'Subtotal'),
'default', $url_button,
'',
true);
6454 if ($usercanvalidate) {
6455 unset($params[
'attr'][
'title']);
6456 print
dolGetButtonAction($langs->trans(
'Validate'),
'',
'default', $_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&action=valid&token='.
newToken(),
'',
true, $params);
6461 if (empty($user->socid)) {
6463 if ($objectidnext) {
6464 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"DisabledBecauseReplacedInvoice").
'">'.$langs->trans(
'SendMail').
'</span>';
6467 unset($params[
'attr'][
'title']);
6468 print
dolGetButtonAction(
'', $langs->trans(
'SendMail'),
'default', $_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=presend&mode=init#formmailbeforetitle',
'',
true, $params);
6470 unset($params[
'attr'][
'title']);
6471 print
dolGetButtonAction(
'', $langs->trans(
'SendMail'),
'default',
'#',
'',
false, $params);
6479 if ($resteapayer > 0) {
6480 if ($usercancreatewithdrarequest) {
6481 if (!$objectidnext &&
$object->close_code !=
'replaced') {
6482 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>';
6484 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"DisabledBecauseReplacedInvoice").
'">'.$langs->trans(
'MakeWithdrawRequest').
'</span>';
6495 if (isModEnabled(
'takepos') &&
$object->module_source ==
'takepos') {
6496 $langs->load(
"cashdesk");
6497 $receipt_url = DOL_URL_ROOT.
"/takepos/receipt.php";
6498 print
'<a target="_blank" rel="noopener noreferrer" class="butAction" href="'.$receipt_url.
'?facid='.((int)
$object->id).
'">'.$langs->trans(
'POSTicket').
'</a>';
6503 if ($objectidnext) {
6504 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"DisabledBecauseReplacedInvoice").
'">'.$langs->trans(
'DoPayment').
'</span>';
6508 $params[
'attr'][
'title'] = $langs->trans(
'DisabledBecauseRemainderToPayIsZero');
6509 print
dolGetButtonAction($langs->trans(
'DoPayment'),
'',
'default',
'#',
'',
false, $params);
6513 unset($params[
'attr'][
'title']);
6514 print
dolGetButtonAction($langs->trans(
'DoPayment'),
'',
'default', DOL_URL_ROOT.
'/compta/paiement.php?facid='.
$object->id.
'&action=create'.(
$object->fk_account > 0 ?
'&accountid='.$object->fk_account :
''),
'', true, $params);
6519 $sumofpayment = $totalpaid;
6520 $sumofpaymentall = $totalpaid + $totalcreditnotes + $totaldeposits;
6526 if ($resteapayer == 0) {
6527 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"DisabledBecauseRemainderToPayIsZero").
'">'.$langs->trans(
'DoPaymentBack').
'</span>';
6529 print
'<a class="butAction" href="'.DOL_URL_ROOT.
'/compta/paiement.php?facid='.
$object->id.
'&action=create&accountid='.
$object->fk_account.
'">'.$langs->trans(
'DoPaymentBack').
'</a>';
6535 print
'<a class="butAction'.($conf->use_javascript_ajax ?
' reposition' :
'').
'" href="'.$_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&action=converttoreduc&token='.
newToken().
'">'.$langs->trans(
'ConvertExcessReceivedToReduc').
'</a>';
6539 && (
getDolGlobalString(
'INVOICE_ALLOW_REUSE_OF_CREDIT_WHEN_PARTIALLY_REFUNDED') || $sumofpayment == 0) &&
$object->total_ht < 0
6541 print
'<a class="butAction classfortooltip'.($conf->use_javascript_ajax ?
' reposition' :
'').
'" href="'.$_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&action=converttoreduc&token='.
newToken().
'" title="'.
dol_escape_htmltag($langs->trans(
"ConfirmConvertToReduc2")).
'">'.$langs->trans(
'ConvertToReduc').
'</a>';
6548 print
'<a class="butAction'.($conf->use_javascript_ajax ?
' reposition' :
'').
'" href="'.$_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&action=converttoreduc&token='.
newToken().
'">'.$langs->trans(
'ConvertToReduc').
'</a>';
6550 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"AmountPaidMustMatchAmountOfDownPayment").
'">'.$langs->trans(
'ConvertToReduc').
'</span>';
6564 $params[
'attr'][
'title'] = $langs->trans(
'AmountPaidMustMatchAmountOfDownPayment');
6565 print
dolGetButtonAction($langs->trans(
'ClassifyPaid'),
'',
'default',
'#',
'',
false, $params);
6567 unset($params[
'attr'][
'title']);
6568 print
dolGetButtonAction($langs->trans(
'ClassifyPaid'),
'',
'default', $_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=paid&token='.
newToken(),
'',
true, $params);
6574 if ($totalpaid > 0 || $totalcreditnotes > 0) {
6576 print
'<a class="butAction'.($conf->use_javascript_ajax ?
' reposition' :
'').
'" href="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=paid&token='.
newToken().
'">'.$langs->trans(
'ClassifyPaidPartially').
'</a>';
6579 if ($objectidnext) {
6580 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"DisabledBecauseReplacedInvoice").
'">'.$langs->trans(
'ClassifyCanceled').
'</span>';
6582 print
'<a class="butAction'.($conf->use_javascript_ajax ?
' reposition' :
'').
'" href="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=canceled">'.$langs->trans(
'ClassifyCanceled').
'</a>';
6590 if (!$objectidnext) {
6591 print
'<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 :
'').(
$object->entity > 0 ?
'&originentity='.$object->entity :
'').
'">'.$langs->trans(
"CreateCreditNote").
'</a>';
6597 &&
$object->isSituationInvoice()
6598 && (
$object->total_ttc - $totalpaid - $totalcreditnotes - $totaldeposits) > 0
6601 &&
$object->is_last_in_cycle()
6604 if ($usercanunvalidate) {
6605 print
'<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>';
6607 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"NotEnoughPermissions").
'">'.$langs->trans(
"CreateCreditNote").
'</span>';
6613 unset($params[
'attr'][
'title']);
6614 print
dolGetButtonAction($langs->trans(
'ToClone'),
'',
'default', $_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=clone&object=invoice&token='.
newToken(),
'',
true, $params);
6619 if (!$objectidnext && count(
$object->lines) > 0) {
6620 unset($params[
'attr'][
'title']);
6621 print
dolGetButtonAction($langs->trans(
'ChangeIntoRepeatableInvoice'),
'',
'default', DOL_URL_ROOT.
'/compta/facture/card-rec.php?facid='.
$object->id.
'&action=create',
'',
true, $params);
6627 &&
$object->isSituationInvoice()
6630 &&
$object->situation_counter > 1
6631 &&
$object->is_last_in_cycle()
6632 && $usercanunvalidate
6634 if ((
$object->total_ttc - $totalcreditnotes) == 0) {
6635 print
'<a id="butSituationOut" class="butAction" href="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=situationout">'.$langs->trans(
"RemoveSituationFromCycle").
'</a>';
6637 print
'<a id="butSituationOutRefused" class="butActionRefused classfortooltip" href="#" title="'.$langs->trans(
"DisabledBecauseNotEnouthCreditNote").
'" >'.$langs->trans(
"RemoveSituationFromCycle").
'</a>';
6643 if (
$object->is_last_in_cycle() &&
$object->situation_final != 1) {
6644 print
'<a class="butAction" href="'.$_SERVER[
'PHP_SELF'].
'?action=create&type=5&origin=facture&originid='.
$object->id.
'&socid='.
$object->socid.
'" >'.$langs->trans(
'CreateNextSituationInvoice').
'</a>';
6645 } elseif (!
$object->is_last_in_cycle()) {
6646 print
'<a class="butActionRefused classfortooltip" href="#" title="'.$langs->trans(
"DisabledBecauseNotLastInCycle").
'">'.$langs->trans(
'CreateNextSituationInvoice').
'</a>';
6648 print
'<a class="butActionRefused classfortooltip" href="#" title="'.$langs->trans(
"DisabledBecauseFinal").
'">'.$langs->trans(
'CreateNextSituationInvoice').
'</a>';
6653 $isErasable =
$object->is_erasable();
6655 if ($isErasable == -4) {
6656 $htmltooltip = $langs->trans(
'DisabledBecausePayments');
6657 } elseif ($isErasable == -3) {
6658 $htmltooltip = $langs->trans(
'DisabledBecauseNotLastSituationInvoice');
6659 } elseif ($isErasable == -2) {
6660 $htmltooltip = $langs->trans(
'DisabledBecauseNotLastInvoice');
6661 } elseif ($isErasable == -1) {
6662 $htmltooltip = $langs->trans(
'DisabledBecauseDispatchedInBookkeeping');
6663 } elseif ($isErasable <= 0) {
6664 $htmltooltip = $langs->trans(
'DisabledBecauseNotErasable');
6665 } elseif ($objectidnext) {
6666 $htmltooltip = $langs->trans(
'DisabledBecauseReplacedInvoice');
6668 if ($usercandelete || ($usercancreate && $isErasable == 1)) {
6669 $enableDelete =
false;
6671 if ($isErasable > 0 && ! $objectidnext) {
6672 $deleteHref = $_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&action=delete&token='.
newToken();
6673 $enableDelete =
true;
6675 unset($params[
'attr'][
'title']);
6676 print
dolGetButtonAction($htmltooltip, $langs->trans(
'Delete'),
'delete', $deleteHref,
'', $enableDelete, $params);
6678 unset($params[
'attr'][
'title']);
6679 print
dolGetButtonAction($htmltooltip, $langs->trans(
'Delete'),
'delete',
'#',
'',
false);
6686 if (
GETPOST(
'modelselected',
'alpha')) {
6687 $action =
'presend';
6689 if ($action !=
'prerelance' && $action !=
'presend') {
6690 print
'<div class="fichecenter"><div class="fichehalfleft">';
6691 print
'<a name="builddoc"></a>';
6696 $urlsource = $_SERVER[
'PHP_SELF'].
'?facid='.
$object->id;
6697 $genallowed = $usercanread;
6698 $delallowed = $usercancreate;
6700 print $formfile->showdocuments(
6720 'remove_file_comfirm'
6723 $somethingshown = $formfile->numoffiles;
6726 $tmparray = $form->showLinkToObjectBlock(
$object, array(), array(
'invoice'), 1);
6727 $linktoelem = $tmparray[
'linktoelem'];
6728 $htmltoenteralink = $tmparray[
'htmltoenteralink'];
6729 print $htmltoenteralink;
6731 $compatibleImportElementsList =
false;
6735 $compatibleImportElementsList = array(
'commande',
'propal',
'subscription');
6737 $somethingshown = $form->showLinkedObjectBlock(
$object, $linktoelem, $compatibleImportElementsList);
6741 include_once DOL_DOCUMENT_ROOT.
'/core/lib/payments.lib.php';
6742 $validpaymentmethod = getValidOnlinePaymentMethods(
'');
6743 $useonlinepayment = count($validpaymentmethod);
6746 print
'<br><!-- Link to pay -->'.
"\n";
6747 require_once DOL_DOCUMENT_ROOT.
'/core/lib/payments.lib.php';
6748 print showOnlinePaymentUrl(
'invoice',
$object->ref).
'<br>';
6751 print
'</div><div class="fichehalfright">';
6755 $morehtmlcenter =
'<div class="nowraponall">';
6756 $morehtmlcenter .=
dolGetButtonTitle($langs->trans(
'FullConversation'),
'',
'fa fa-comments imgforviewmode', DOL_URL_ROOT.
'/compta/facture/messaging.php?id='.
$object->id);
6757 $morehtmlcenter .=
dolGetButtonTitle($langs->trans(
'FullList'),
'',
'fa fa-bars imgforviewmode', DOL_URL_ROOT.
'/compta/facture/agenda.php?id='.
$object->id);
6758 $morehtmlcenter .=
'</div>';
6761 include_once DOL_DOCUMENT_ROOT.
'/core/class/html.formactions.class.php';
6763 $somethingshown = $formactions->showactions(
$object,
'invoice', $socid, 1,
'', $MAXEVENT,
'', $morehtmlcenter);
6765 print
'</div></div>';
6770 $modelmail =
'facture_send';
6771 $defaulttopic =
'SendBillRef';
6772 $diroutput =
$conf->invoice->multidir_output[
$object->entity];
6773 $trackid =
'inv'.$object->id;
6775 include DOL_DOCUMENT_ROOT.
'/core/tpl/card_presend.tpl.php';
$id
Support class for third parties, contacts, members, users or resources.
if( $user->socid > 0) if(! $user->hasRight('accounting', 'chartofaccount')) $object
ajax_combobox($htmlname, $events=array(), $minLengthToAutocomplete=0, $forcefocus=0, $widthTypeOfAutocomplete='resolve', $idforemptyvalue='-1', $morecss='')
Convert a html select field into an ajax combobox.
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader($head='', $title='', $help_url='', $target='', $disablejs=0, $disablehead=0, $arrayofjs='', $arrayofcss='', $morequerystring='', $morecssonbody='', $replacemainareaby='', $disablenofollow=0, $disablenoindex=0)
Empty header.
Class to manage bank accounts.
Class to manage accounting journals.
Class to manage absolute discounts.
Class to manage a WYSIWYG editor.
Class to manage warehouses.
Class to manage invoices.
const TYPE_REPLACEMENT
Replacement invoice.
const STATUS_DRAFT
Draft status.
const TYPE_STANDARD
Standard invoice.
const TYPE_SITUATION
Situation invoice.
const TYPE_PROFORMA
Proforma invoice (should not be used.
const STATUS_VALIDATED
Validated (need to be paid)
const TYPE_DEPOSIT
Deposit invoice.
const STATUS_ABANDONED
Classified abandoned and no payment done.
const TYPE_CREDIT_NOTE
Credit note invoice.
const STATUS_CLOSED
Classified paid.
Class to manage invoice lines.
Class to manage invoice templates.
static liste_modeles($db, $maxfilenamelength=0)
Return list of active generation modules.
Class to manage the table of subscription to notifications.
Class to manage payments of customer invoices.
Class ProductCombination Used to represent the relation between a product and one of its variants.
Class to manage products or services.
const TYPE_PRODUCT
Regular product.
Class to manage projects.
Class to manage third parties objects (customers, suppliers, prospects...)
Class to manage translations.
Class to manage Dolibarr users.
getCountry($searchkey, $withcode='', $dbtouse=null, $outputlangs=null, $entconv=1, $searchlabel='')
Return country label, code or id from an id, code or label.
dol_get_last_hour($date, $gm='tzserver')
Return GMT time for last hour of a given GMT date (it replaces hours, min and second part to 23:59:59...
dol_time_plus_duree($time, $duration_value, $duration_unit, $ruleforendofmonth=0)
Add a delay to a date.
dol_stringtotime($string, $gm=1)
Convert a string date into a GM Timestamps date Warning: YYYY-MM-DDTHH:MM:SS+02:00 (RFC3339) is not s...
print $script_file $mode $langs defaultlang(is_numeric($duration_value) ? " delay=". $duration_value :"").(is_numeric($duration_value2) ? " after cd cd cd description as description
Only used if Module[ID]Desc translation string is not found.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed information (by default a local PHP server timestamp) Rep...
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
Show picto whatever it's its name (generic function)
img_warning($titlealt='default', $moreatt='', $morecss='pictowarning')
Show warning logo.
img_delete($titlealt='default', $other='class="pictodelete"', $morecss='')
Show delete logo.
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0, $morecssdiv='')
Show tabs of a record.
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
dolGetButtonTitle($label, $helpText='', $iconClass='fa fa-file', $url='', $id='', $status=1, $params=array())
Function dolGetButtonTitle : this kind of buttons are used in title in list.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
dol_eval($s, $returnvalue=1, $hideerrors=1, $onlysimplestring='1')
Replace eval function to add more security.
price($amount, $form=0, $outlangs='', $trunc=1, $rounding=-1, $forcerounding=-1, $currency_code='')
Function to format a value into an amount for visual output Function used into PDF and HTML pages.
GETPOSTISARRAY($paramname, $method=0)
Return true if the parameter $paramname is submit from a POST OR GET as an array.
dol_now($mode='auto')
Return date for now.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
if(!function_exists( 'dol_getprefix')) dol_include_once($relpath, $classname='')
Make an include_once using default root and alternate root if it fails.
newToken()
Return the value of token currently saved into session with name 'newtoken'.
dolGetButtonAction($label, $text='', $actionType='default', $url='', $id='', $userRight=1, $params=array())
Function dolGetButtonAction.
dol_htmlcleanlastbr($stringtodecode)
This function remove all ending and br at end.
dol_concatdesc($text1, $text2, $forxml=false, $invert=false)
Concat 2 descriptions with a new line between them (second operand after first one with appropriate n...
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
GETPOSTFLOAT($paramname, $rounding='')
Return the value of a $_GET or $_POST supervariable, converted into float.
dol_buildpath($path, $type=0, $returnemptyifnotfound=0)
Return path of url or filesystem.
dol_clone($object, $native=2)
Create a clone of instance of object (new instance with same value for each properties) With native =...
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
dol_sanitizeFileName($str, $newstr='_', $unaccent=1, $includequotes=0)
Clean a string to use it as a file name.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
info_admin($text, $infoonimgalt=0, $nodiv=0, $admin='1', $morecss='hideonsmartphone', $textfordropdown='', $picto='')
Show information in HTML for admin users or standard users.
img_edit($titlealt='default', $float=0, $other='')
Show logo edit/modify fiche.
get_default_tva(Societe $thirdparty_seller, Societe $thirdparty_buyer, $idprod=0, $idprodfournprice=0)
Function that return vat rate of a product line (according to seller, buyer and product vat rate) VAT...
getDictionaryValue($tablename, $field, $id, $checkentity=false, $rowidfield='rowid')
Return the value of a filed into a dictionary for the record $id.
get_localtax($vatrate, $local, $thirdparty_buyer=null, $thirdparty_seller=null, $vatnpr=0)
Return localtax rate for a particular vat, when selling a product with vat $vatrate,...
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
dol_getdate($timestamp, $fast=false, $forcetimezone='')
Return an array with locale date info.
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0, $cleanalsojavascript=0)
Returns text escaped for inclusion in HTML alt or title or value tags, or into values of HTML input f...
facture_prepare_head($object)
Initialize the array of tabs for customer invoice.
global $conf
The following vars must be defined: $type2label $form $conf, $lang, The following vars may also be de...
calcul_price_total($qty, $pu, $remise_percent_ligne, $txtva, $uselocaltax1_rate, $uselocaltax2_rate, $remise_percent_global, $price_base_type, $info_bits, $type, $seller=null, $localtaxes_array=[], $progress=100, $multicurrency_tx=1, $pu_devise=0, $multicurrency_code='')
Calculate totals (net, vat, ...) of a line.
if(preg_match('/(crypted|dolcrypt):/i', $dolibarr_main_db_pass)||!empty($dolibarr_main_db_encrypted_pass)) $conf db type
restrictedArea(User $user, $features, $object=0, $tableandshare='', $feature2='', $dbt_keyfield='fk_soc', $dbt_select='rowid', $isdraft=0, $mode=0)
Check permissions of a user to show a page and an object.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.