47require
'../../main.inc.php';
57require_once DOL_DOCUMENT_ROOT.
'/categories/class/categorie.class.php';
58require_once DOL_DOCUMENT_ROOT.
'/compta/facture/class/facture.class.php';
59require_once DOL_DOCUMENT_ROOT.
'/compta/facture/class/facture-rec.class.php';
60require_once DOL_DOCUMENT_ROOT.
'/compta/bank/class/account.class.php';
61require_once DOL_DOCUMENT_ROOT.
'/compta/paiement/class/paiement.class.php';
62require_once DOL_DOCUMENT_ROOT.
'/core/modules/facture/modules_facture.php';
63require_once DOL_DOCUMENT_ROOT.
'/core/class/discount.class.php';
64require_once DOL_DOCUMENT_ROOT.
'/core/class/extrafields.class.php';
65require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formfile.class.php';
66require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formother.class.php';
67require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formmargin.class.php';
68require_once DOL_DOCUMENT_ROOT.
'/core/lib/invoice.lib.php';
69require_once DOL_DOCUMENT_ROOT.
'/core/lib/functions2.lib.php';
70require_once DOL_DOCUMENT_ROOT.
'/core/lib/date.lib.php';
72 require_once DOL_DOCUMENT_ROOT.
'/commande/class/commande.class.php';
75 require_once DOL_DOCUMENT_ROOT.
'/projet/class/project.class.php';
76 require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formprojet.class.php';
78require_once DOL_DOCUMENT_ROOT.
'/core/class/doleditor.class.php';
81 require_once DOL_DOCUMENT_ROOT.
'/variants/class/ProductCombination.class.php';
84 require_once DOL_DOCUMENT_ROOT.
'/accountancy/class/accountingjournal.class.php';
88$langs->loadLangs(array(
'bills',
'companies',
'compta',
'products',
'banks',
'main',
'withdrawals'));
90 $langs->load(
'incoterm');
93 $langs->load(
'margins');
97$action =
GETPOST(
'action',
'aZ09');
98$confirm =
GETPOST(
'confirm',
'alpha');
99$cancel =
GETPOST(
'cancel',
'alpha');
100$backtopage =
GETPOST(
'backtopage',
'alpha');
101$backtopageforcancel =
GETPOST(
'backtopageforcancel',
'alpha');
107$origin =
GETPOST(
'origin',
'alpha');
111$ref_client =
GETPOST(
'ref_client',
'alpha');
112$inputReasonId =
GETPOSTINT(
'input_reason_id');
115$selectedLines =
GETPOST(
'toselect',
'array:int');
128$extrafields->fetch_name_optionals_label(
$object->table_element);
131$total_global_ttc = 0;
132$displayWarranty =
false;
133$statusreplacement = 0;
135$price_base_type =
'';
136$array_options = array();
139if ($id > 0 || !empty($ref)) {
140 if ($action !=
'add') {
142 $fetch_situation =
false;
144 $fetch_situation =
true;
146 $ret =
$object->fetch($id, $ref,
'', 0, $fetch_situation);
147 if ($ret > 0 && isset(
$object->fk_project)) {
148 $ret =
$object->fetchProject();
154$hookmanager->initHooks(array(
'invoicecard',
'globalcard'));
157$usercanread = $user->hasRight(
"facture",
"lire");
158$usercancreate = $user->hasRight(
"facture",
"creer");
159$usercanissuepayment = $user->hasRight(
"facture",
"paiement");
160$usercandelete = $user->hasRight(
"facture",
"supprimer") || ($usercancreate && isset(
$object->status) &&
$object->status == $object::STATUS_DRAFT);
161$usercancreatecontract = $user->hasRight(
"contrat",
"creer");
164$usercanvalidate = ((!
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $usercancreate) || (
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $user->hasRight(
'facture',
'invoice_advance',
'validate')));
165$usercansend = ((!
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $usercanread) || (
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $user->hasRight(
'facture',
'invoice_advance',
'send')));
166$usercanreopen = ((!
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $usercancreate) || (
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $user->hasRight(
'facture',
'invoice_advance',
'reopen')));
168 $usercanreopen =
false;
170$usercanunvalidate = ((!
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && !empty($usercancreate)) || (
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $user->hasRight(
'facture',
'invoice_advance',
'unvalidate')));
171$usermustrespectpricemin = ((
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && !$user->hasRight(
'produit',
'ignore_price_min_advance')) || !
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS'));
174$usercancreatemargin = $user->hasRight(
'margins',
'creer');
175$usercanreadallmargin = $user->hasRight(
'margins',
'liretous');
176$usercancreatewithdrarequest = $user->hasRight(
'prelevement',
'bons',
'creer');
178$permissionnote = $usercancreate;
179$permissiondellink = $usercancreate;
180$permissiontoedit = $usercancreate;
181$permissiontoadd = $usercancreate;
182$permissiontoeditextra = $usercancreate;
183if (
GETPOST(
'attribute',
'aZ09') && isset($extrafields->attributes[
$object->table_element][
'perms'][
GETPOST(
'attribute',
'aZ09')])) {
185 $permissiontoeditextra =
dol_eval((
string) $extrafields->attributes[
$object->table_element][
'perms'][
GETPOST(
'attribute',
'aZ09')]);
189$retainedWarrantyInvoiceAvailableType = array();
191 $retainedWarrantyInvoiceAvailableType = explode(
'+',
getDolGlobalString(
'INVOICE_USE_RETAINED_WARRANTY'));
196 $socid = $user->socid;
209$parameters = array(
'socid' => $socid);
210$reshook = $hookmanager->executeHooks(
'doActions', $parameters, $object, $action);
215if (empty($reshook)) {
216 $backurlforlist =
dolBuildUrl(DOL_URL_ROOT.
'/compta/facture/list.php');
218 if (empty($backtopage) || ($cancel && empty($id))) {
219 if (empty($backtopage) || ($cancel && strpos($backtopage,
'__ID__'))) {
220 if (empty($id) && (($action !=
'add' && $action !=
'create') || $cancel)) {
221 $backtopage = $backurlforlist;
223 $backtopage =
dolBuildUrl(DOL_URL_ROOT.
'/compta/facture/card.php', [
'id' => ((!empty($id) && $id > 0) ? $id :
'__ID__')]);
229 if (!empty($backtopageforcancel)) {
230 header(
"Location: ".$backtopageforcancel);
232 } elseif (!empty($backtopage)) {
233 header(
"Location: ".$backtopage);
239 include DOL_DOCUMENT_ROOT.
'/core/actions_setnotes.inc.php';
241 include DOL_DOCUMENT_ROOT.
'/core/actions_dellink.inc.php';
243 include DOL_DOCUMENT_ROOT.
'/core/actions_lineupdown.inc.php';
246 if ($action ==
'confirm_clone' && $confirm ==
'yes' && $permissiontoadd) {
248 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'IdThirdParty')),
null,
'errors');
251 '@phan-var-force Facture $objectutil';
254 $objectutil->socid = $socid;
255 $result = $objectutil->createFromClone($user, $id, (GETPOSTISSET(
'entity') ?
GETPOSTINT(
'entity') : null));
257 $warningMsgLineList = array();
259 foreach ($objectutil->lines as $line) {
260 if (!is_object($line->product)) {
261 $line->fetch_product();
263 if (is_object($line->product) && $line->product->id > 0) {
264 if (empty($line->product->status)) {
265 $warningMsgLineList[$line->id] = $langs->trans(
'WarningLineProductNotToSell', $line->product->ref);
269 if (!empty($warningMsgLineList)) {
273 header(
"Location: " . $_SERVER[
'PHP_SELF'] .
'?facid=' . $result);
276 $langs->load(
"errors");
281 } elseif ($action ==
'reopen' && $usercanreopen) {
285 $result =
$object->setUnpaid($user);
287 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
293 } elseif ($action ==
'confirm_delete' && $confirm ==
'yes' && $usercandelete) {
298 $idwarehouse =
GETPOST(
'idwarehouse');
300 $qualified_for_stock_change = 0;
302 $qualified_for_stock_change =
$object->hasProductsOrServices(2);
304 $qualified_for_stock_change =
$object->hasProductsOrServices(1);
307 $isErasable =
$object->is_erasable();
309 if (($isErasable > 0) || ($usercancreate && $isErasable == 1)) {
310 $result =
$object->delete($user, 0, (
int) $idwarehouse);
312 header(
'Location: '.DOL_URL_ROOT.
'/compta/facture/list.php?restore_lastsearch_values=1');
319 } elseif ($action ==
'confirm_deleteline' && $confirm ==
'yes' && $usercancreate) {
329 $outputlangs = $langs;
335 $newlang =
$object->thirdparty->default_lang;
337 if (!empty($newlang)) {
339 $outputlangs->setDefaultLang($newlang);
340 $outputlangs->load(
'products');
344 $result =
$object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
347 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
354 } elseif ($action ==
'confirm_delete_subtotalline' && $confirm ==
'yes' && $usercancreate) {
359 $result =
$object->deleteSubtotalLine($langs,
GETPOSTINT(
'lineid'), (
bool)
GETPOST(
'deletecorrespondingsubtotalline'));
364 $outputlangs = $langs;
370 $newlang =
$object->thirdparty->default_lang;
372 if (!empty($newlang)) {
374 $outputlangs->setDefaultLang($newlang);
375 $outputlangs->load(
'products');
379 $result =
$object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
382 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
389 } elseif ($action ==
'unlinkdiscount' && $usercancreate) {
392 $result = $discount->fetch(
GETPOSTINT(
"discountid"));
393 $discount->unlink_invoice();
394 } elseif ($action ==
'valid' && $usercancreate) {
398 if ((preg_match(
'/^[\(]?PROV/i',
$object->ref) || empty(
$object->ref)) &&
405 $last_of_type =
$object->willBeLastOfSameType(
true);
406 if (empty(
$object->date_validation) && !$last_of_type[0]) {
416 setEventMessages($langs->trans(
"ErrorInvoiceAvoirMustBeNegative"),
null,
'errors');
425 setEventMessages($langs->trans(
"ErrorInvoiceOfThisTypeMustBePositive"),
null,
'errors');
434 $array_of_total_ht_per_vat_rate = array();
435 $array_of_total_ht_devise_per_vat_rate = array();
436 foreach (
$object->lines as $line) {
438 $vat_src_code_for_line =
'';
439 if (empty($array_of_total_ht_per_vat_rate[$line->tva_tx.
'_'.$vat_src_code_for_line])) {
440 $array_of_total_ht_per_vat_rate[$line->tva_tx.
'_'.$vat_src_code_for_line] = 0;
442 if (empty($array_of_total_ht_devise_per_vat_rate[$line->tva_tx.
'_'.$vat_src_code_for_line])) {
443 $array_of_total_ht_devise_per_vat_rate[$line->tva_tx.
'_'.$vat_src_code_for_line] = 0;
445 $array_of_total_ht_per_vat_rate[$line->tva_tx.
'_'.$vat_src_code_for_line] += $line->total_ht;
446 $array_of_total_ht_devise_per_vat_rate[$line->tva_tx.
'_'.$vat_src_code_for_line] += $line->multicurrency_total_ht;
450 foreach ($array_of_total_ht_per_vat_rate as $vatrate => $tmpvalue) {
451 $tmp_total_ht =
price2num($array_of_total_ht_per_vat_rate[$vatrate]);
452 $tmp_total_ht_devise =
price2num($array_of_total_ht_devise_per_vat_rate[$vatrate]);
454 if (($tmp_total_ht < 0 || $tmp_total_ht_devise < 0) && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES')) {
455 if (
$object->type == $object::TYPE_DEPOSIT) {
456 $langs->load(
"errors");
458 setEventMessages($langs->trans(
"ErrorLinesCantBeNegativeOnDeposits"),
null,
'errors');
462 $tmpvatratetoshow = explode(
'_', $vatrate);
463 $tmpvatratetoshow[0] = round((
float) $tmpvatratetoshow[0], 2);
465 if ($tmpvatratetoshow[0] != 0) {
466 $langs->load(
"errors");
467 setEventMessages($langs->trans(
"ErrorLinesCantBeNegativeForOneVATRate", (
string) $tmpvatratetoshow[0]),
null,
'errors');
475 } elseif ($action ==
'classin' && $usercancreate) {
481 } elseif ($action ==
'setposinfo' && $usercancreate) {
485 $result =
$object->update($user);
489 } elseif ($action ==
'setmode' && $usercancreate) {
495 } elseif ($action ==
'setretainedwarrantyconditions' && $usercancreate) {
498 $object->retained_warranty_fk_cond_reglement = 0;
499 $result =
$object->setRetainedWarrantyPaymentTerms(
GETPOSTINT(
'retained_warranty_fk_cond_reglement'));
504 $old_rw_date_lim_reglement =
$object->retained_warranty_date_limit;
505 $new_rw_date_lim_reglement =
$object->calculate_date_lim_reglement(
$object->retained_warranty_fk_cond_reglement);
506 if ($new_rw_date_lim_reglement > $old_rw_date_lim_reglement) {
507 $object->retained_warranty_date_limit = $new_rw_date_lim_reglement;
512 $result =
$object->update($user);
516 } elseif ($action ==
'setretainedwarranty' && $usercancreate) {
522 } elseif ($action ==
'setretainedwarrantydatelimit' && $usercancreate) {
524 $result =
$object->setRetainedWarrantyDateLimit(
GETPOSTDATE(
'retained_warranty_date_limit'));
528 } elseif ($action ==
'setmulticurrencycode' && $usercancreate) {
529 $result =
$object->setMulticurrencyCode(
GETPOST(
'multicurrency_code',
'alpha'));
530 } elseif ($action ==
'setmulticurrencyrate' && $usercancreate) {
532 } elseif ($action ==
'setinvoicedate' && $usercancreate) {
534 $old_date_lim_reglement =
$object->date_lim_reglement;
536 if (empty($newdate)) {
537 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Date")),
null,
'errors');
538 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.
$id.
'&action=editinvoicedate&token='.newToken());
543 setEventMessages($langs->trans(
"WarningInvoiceDateInFuture"),
null,
'warnings');
545 setEventMessages($langs->trans(
"WarningInvoiceDateTooFarInFuture"),
null,
'warnings');
550 $new_date_lim_reglement =
$object->calculate_date_lim_reglement();
551 if ($new_date_lim_reglement) {
552 $object->date_lim_reglement = $new_date_lim_reglement;
557 $result =
$object->update($user);
560 $action =
'editinvoicedate';
562 } elseif ($action ==
'setdate_pointoftax' && $usercancreate) {
567 $object->date_pointoftax = $date_pointoftax;
568 $result =
$object->update($user);
572 } elseif ($action ==
'setconditions' && $usercancreate) {
574 $object->cond_reglement_code = 0;
575 $object->cond_reglement_id = 0;
588 $old_date_lim_reglement =
$object->date_lim_reglement;
589 $new_date_lim_reglement =
$object->calculate_date_lim_reglement();
590 if ($new_date_lim_reglement) {
591 $object->date_lim_reglement = $new_date_lim_reglement;
596 $result =
$object->update($user);
608 } elseif ($action ==
'setpaymentterm' && $usercancreate) {
612 $object->date_lim_reglement =
$object->calculate_date_lim_reglement();
613 setEventMessages($langs->trans(
"DatePaymentTermCantBeLowerThanObjectDate"),
null,
'warnings');
615 $result =
$object->update($user);
619 } elseif ($action ==
'setrevenuestamp' && $usercancreate) {
622 $result =
$object->update($user);
629 $outputlangs = $langs;
632 $newlang =
GETPOST(
'lang_id',
'aZ09');
635 $newlang =
$object->thirdparty->default_lang;
637 if (!empty($newlang)) {
639 $outputlangs->setDefaultLang($newlang);
640 $outputlangs->load(
'products');
645 $result =
$object->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
651 } elseif ($action ==
'set_incoterms' &&
isModEnabled(
'incoterm') && $usercancreate) {
656 } elseif ($action ==
'set_dispute_status' && $usercancreate) {
657 $result =
$object->setStatut(
GETPOSTINT(
'dispute_status'),
null,
'facture',
'FACTURE_MODIFY',
'dispute_status');
661 } elseif ($action ==
'settags' &&
isModEnabled(
'category') && $usercancreate) {
666 } elseif ($action ==
'setbankaccount' && $usercancreate) {
671 } elseif ($action ==
'setremisepercent' && $usercancreate) {
677 } elseif ($action ==
'setabsolutediscount' && $usercancreate) {
696 $newremaintopay =
$object->getRemainToPay(0);
697 if ($newremaintopay == 0) {
704 if (
GETPOSTINT(
"remise_id_for_payment") > 0) {
705 require_once DOL_DOCUMENT_ROOT.
'/core/class/discount.class.php';
707 $discount->fetch(
GETPOSTINT(
"remise_id_for_payment"));
711 $remaintopay =
$object->getRemainToPay(0);
715 setEventMessages($langs->trans(
"ErrorDiscountLargerThanRemainToPaySplitItBefore"),
null,
'errors');
719 $result = $discount->link_to_invoice(0, $id);
732 $newremaintopay =
$object->getRemainToPay(0);
733 if ($newremaintopay == 0) {
747 $outputlangs = $langs;
750 $newlang =
GETPOST(
'lang_id',
'aZ09');
754 $newlang =
$object->thirdparty->default_lang;
756 if (!empty($newlang)) {
758 $outputlangs->setDefaultLang($newlang);
762 $result =
$object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
767 } elseif ($action ==
'setref' && $usercancreate) {
769 $object->setValueFrom(
'ref',
GETPOST(
'ref'),
'', 0,
'',
'', $user,
'BILL_MODIFY');
773 } elseif ($action ==
'setref_client' && $usercancreate) {
779 } elseif ($action ==
'setdemandreason' && $usercancreate) {
780 $result =
$object->setInputReason($inputReasonId);
784 } elseif ($action ==
'confirm_valid' && $confirm ==
'yes' && $usercanvalidate) {
793 $qualified_for_stock_change = 0;
795 $qualified_for_stock_change =
$object->hasProductsOrServices(2);
797 $qualified_for_stock_change =
$object->hasProductsOrServices(1);
800 if ($qualified_for_stock_change) {
801 if (!$idwarehouse || $idwarehouse == - 1) {
803 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
"Warehouse")),
null,
'errors');
810 $result =
$object->validate($user,
'', $idwarehouse);
814 $outputlangs = $langs;
817 $newlang =
GETPOST(
'lang_id',
'aZ09');
820 $newlang =
$object->thirdparty->default_lang;
822 if (!empty($newlang)) {
824 $outputlangs->setDefaultLang($newlang);
825 $outputlangs->load(
'products');
831 $result =
$object->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
844 } elseif ($action ==
'confirm_modif' && $usercanunvalidate && !
getDolGlobalString(
'INVOICE_CAN_NEVER_BE_EDITED')) {
853 $qualified_for_stock_change = 0;
855 $qualified_for_stock_change =
$object->hasProductsOrServices(2);
857 $qualified_for_stock_change =
$object->hasProductsOrServices(1);
860 if ($qualified_for_stock_change) {
861 if (!$idwarehouse || $idwarehouse == -1) {
863 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
"Warehouse")),
null,
'errors');
872 $sql =
'SELECT pf.amount';
873 $sql .=
' FROM ' . MAIN_DB_PREFIX .
'paiement_facture as pf';
874 $sql .=
' WHERE pf.fk_facture = ' . ((int)
$object->id);
876 $result =
$db->query($sql);
879 $num =
$db->num_rows($result);
882 $objp =
$db->fetch_object($result);
883 $totalpaid += $objp->amount;
890 $resteapayer =
$object->total_ttc - $totalpaid;
893 $ventilExportCompta =
$object->getVentilExportCompta();
896 if ($ventilExportCompta == 0) {
899 $result =
$object->setDraft($user, $idwarehouse);
906 $outputlangs = $langs;
909 $newlang =
GETPOST(
'lang_id',
'aZ09');
912 $newlang =
$object->thirdparty->default_lang;
914 if (!empty($newlang)) {
916 $outputlangs->setDefaultLang($newlang);
917 $outputlangs->load(
'products');
922 $object->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
928 } elseif ($action ==
'confirm_paid' && $confirm ==
'yes' && $usercanissuepayment) {
931 $result =
$object->setPaid($user);
935 } elseif ($action ==
'confirm_paid_partially' && $confirm ==
'yes' && $usercanissuepayment) {
938 $close_code =
GETPOST(
"close_code",
'restricthtml');
939 $close_note =
GETPOST(
"close_note",
'restricthtml');
942 if (
isModEnabled(
'tax') && $close_code == $object::CLOSECODE_WITHHOLDINGTAX) {
943 require_once DOL_DOCUMENT_ROOT.
'/compta/tva/class/tva.class.php';
945 $amount = (float) ($resteapayer > 0 ? $resteapayer * -1 : $resteapayer);
949 $tempTva->datev =
$object->date;
950 $tempTva->datep =
$object->date;
951 $tempTva->amount = $amount;
952 $tempTva->label = $langs->trans(
'WithholdingTax') .
' - ' .
$object->ref;
954 $valid = $tempTva->getIdForLabel($tempTva->label);
956 $ret = $tempTva->create($user);
960 $tempTva->setPaid($user);
970 setEventMessages($langs->trans(
'LabelWithholdingExist'), $tempTva->errors,
'errors');
976 $result =
$object->setPaid($user, $close_code, $close_note);
984 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Reason")),
null,
'errors');
986 } elseif ($action ==
'confirm_canceled' && $confirm ==
'yes' && $usercancreate) {
989 $close_code =
GETPOST(
"close_code",
'restricthtml');
990 $close_note =
GETPOST(
"close_note",
'restricthtml');
992 $result =
$object->setCanceled($user, $close_code, $close_note);
999 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Reason")),
null,
'errors');
1001 } elseif ($action ==
'confirm_converttoreduc' && $confirm ==
'yes' && $usercancreate) {
1009 $result = $discountcheck->fetch(0,
$object->id);
1022 $amount_ht = $amount_tva = $amount_ttc = $amount_localtax1 = $amount_localtax2 = array();
1023 $multicurrency_amount_ht = $multicurrency_amount_tva = $multicurrency_amount_ttc = array();
1027 foreach (
$object->lines as $line) {
1028 if ($line->product_type < 9 && $line->total_ht != 0) {
1029 $keyforvatrate = $line->tva_tx.($line->vat_src_code ?
' ('.$line->vat_src_code.
')' :
'');
1031 if (!isset($amount_ht[$keyforvatrate])) {
1032 $amount_ht[$keyforvatrate] = 0;
1034 $amount_ht[$keyforvatrate] += $line->total_ht;
1035 if (!isset($amount_tva[$keyforvatrate])) {
1036 $amount_tva[$keyforvatrate] = 0;
1038 $amount_tva[$keyforvatrate] += $line->total_tva;
1039 if (!isset($amount_localtax1[$keyforvatrate])) {
1040 $amount_localtax1[$keyforvatrate] = 0;
1042 $amount_localtax1[$keyforvatrate] += $line->total_localtax1;
1043 if (!isset($amount_localtax2[$keyforvatrate])) {
1044 $amount_localtax2[$keyforvatrate] = 0;
1046 $amount_localtax2[$keyforvatrate] += $line->total_localtax2;
1047 if (!isset($amount_ttc[$keyforvatrate])) {
1048 $amount_ttc[$keyforvatrate] = 0;
1050 $amount_ttc[$keyforvatrate] += $line->total_ttc;
1051 if (!isset($multicurrency_amount_ht[$keyforvatrate])) {
1052 $multicurrency_amount_ht[$keyforvatrate] = 0;
1054 $multicurrency_amount_ht[$keyforvatrate] += $line->multicurrency_total_ht;
1055 if (!isset($multicurrency_amount_tva[$keyforvatrate])) {
1056 $multicurrency_amount_tva[$keyforvatrate] = 0;
1058 $multicurrency_amount_tva[$keyforvatrate] += $line->multicurrency_total_tva;
1059 if (!isset($multicurrency_amount_ttc[$keyforvatrate])) {
1060 $multicurrency_amount_ttc[$keyforvatrate] = 0;
1062 $multicurrency_amount_ttc[$keyforvatrate] += $line->multicurrency_total_ttc;
1066 '@phan-var-force array<string,float> $amount_ht
1067 @phan-var-force array<string,float> $amount_tva
1068 @phan-var-force array<string,float> $amount_ttc
1069 @phan-var-force array<string,float> $amount_localtax1
1070 @phan-var-force array<string,float> $amount_localtax2
1071 @phan-var-force array<string,float> $multicurrency_amount_ht
1072 @phan-var-force array<string,float> $multicurrency_amount_tva
1073 @phan-var-force array<string,float> $multicurrency_amount_ttc';
1077 $alreadypaid =
$object->getSommePaiement();
1078 if ($alreadypaid && abs($alreadypaid) < abs(
$object->total_ttc)) {
1079 $ratio = abs((
$object->total_ttc - $alreadypaid) /
$object->total_ttc);
1080 foreach ($amount_ht as $vatrate => $val) {
1081 $amount_ht[$vatrate] =
price2num($amount_ht[$vatrate] * $ratio,
'MU');
1082 $amount_tva[$vatrate] =
price2num($amount_tva[$vatrate] * $ratio,
'MU');
1083 $amount_ttc[$vatrate] =
price2num($amount_ttc[$vatrate] * $ratio,
'MU');
1084 $amount_localtax1[$vatrate] =
price2num($amount_localtax1[$vatrate] * $ratio,
'MU');
1085 $amount_localtax2[$vatrate] =
price2num($amount_localtax2[$vatrate] * $ratio,
'MU');
1086 $multicurrency_amount_ht[$vatrate] =
price2num($multicurrency_amount_ht[$vatrate] * $ratio,
'MU');
1087 $multicurrency_amount_tva[$vatrate] =
price2num($multicurrency_amount_tva[$vatrate] * $ratio,
'MU');
1088 $multicurrency_amount_ttc[$vatrate] =
price2num($multicurrency_amount_ttc[$vatrate] * $ratio,
'MU');
1097 $discount->description =
'(CREDIT_NOTE)';
1099 $discount->description =
'(DEPOSIT)';
1101 $discount->description =
'(EXCESS RECEIVED)';
1103 setEventMessages($langs->trans(
'CantConvertToReducAnInvoiceOfThisType'),
null,
'errors');
1105 $discount->fk_soc =
$object->socid;
1106 $discount->socid =
$object->socid;
1107 $discount->fk_facture_source =
$object->id;
1116 $discount->description =
'(EXCESS RECEIVED)';
1119 $sql =
'SELECT SUM(pf.amount) as total_paiements';
1120 $sql .=
' FROM '.MAIN_DB_PREFIX.
'paiement_facture as pf, '.MAIN_DB_PREFIX.
'paiement as p';
1121 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_paiement as c ON p.fk_paiement = c.id';
1122 $sql .=
' WHERE pf.fk_facture = '.((int)
$object->id);
1123 $sql .=
' AND pf.fk_paiement = p.rowid';
1124 $sql .=
' AND p.entity IN ('.getEntity(
'invoice').
')';
1125 $resql =
$db->query($sql);
1130 $res =
$db->fetch_object($resql);
1131 $total_paiements = $res->total_paiements;
1134 $total_creditnote_and_deposit = 0;
1135 $sql =
"SELECT re.rowid, re.amount_ht, re.amount_tva, re.amount_ttc,";
1136 $sql .=
" re.description, re.fk_facture_source";
1137 $sql .=
" FROM ".MAIN_DB_PREFIX.
"societe_remise_except as re";
1138 $sql .=
" WHERE fk_facture = ".((int)
$object->id);
1139 $resql =
$db->query($sql);
1140 if (!empty($resql)) {
1141 while ($obj =
$db->fetch_object($resql)) {
1142 $total_creditnote_and_deposit += $obj->amount_ttc;
1148 $discount->amount_ttc =
price2num($total_paiements + $total_creditnote_and_deposit -
$object->total_ttc,
'MT');
1149 $discount->amount_tva = 0;
1150 $discount->amount_ht = $discount->amount_ttc;
1151 $discount->tva_tx = 0;
1152 $discount->localtax1_tx = 0;
1153 $discount->localtax1_type = 0;
1154 $discount->localtax2_tx = 0;
1155 $discount->localtax2_type = 0;
1156 $discount->vat_src_code =
'';
1158 if ($discount->amount_ttc > 0) {
1159 $result = $discount->create($user);
1169 $discount->description =
'(CREDIT_NOTE)';
1171 $discount->description =
'(DEPOSIT)';
1174 foreach ($amount_ht as $tva_tx => $xxx) {
1179 $discount->amount_ht = -((float) $amount_ht[$tva_tx]);
1180 $discount->amount_tva = -((float) $amount_tva[$tva_tx]);
1181 $discount->amount_ttc = -((float) $amount_ttc[$tva_tx]);
1182 $discount->total_ht = -((float) $amount_ht[$tva_tx]);
1183 $discount->total_tva = -((float) $amount_tva[$tva_tx]);
1184 $discount->total_localtax1 = -((float) $amount_localtax1[$tva_tx]);
1185 $discount->total_localtax2 = -((float) $amount_localtax2[$tva_tx]);
1186 $discount->total_ttc = -((float) $amount_ttc[$tva_tx]);
1187 $discount->multicurrency_amount_ht = -((float) $multicurrency_amount_ht[$tva_tx]);
1188 $discount->multicurrency_amount_tva = -((float) $multicurrency_amount_tva[$tva_tx]);
1189 $discount->multicurrency_amount_ttc = -((float) $multicurrency_amount_ttc[$tva_tx]);
1190 $discount->multicurrency_total_ht = -((float) $multicurrency_amount_ht[$tva_tx]);
1191 $discount->multicurrency_total_tva = -((float) $multicurrency_amount_tva[$tva_tx]);
1192 $discount->multicurrency_total_ttc = -((float) $multicurrency_amount_ttc[$tva_tx]);
1195 $discount->amount_ht = abs((
float) $amount_ht[$tva_tx]);
1196 $discount->amount_tva = abs((
float) $amount_tva[$tva_tx]);
1197 $discount->amount_ttc = abs((
float) $amount_ttc[$tva_tx]);
1198 $discount->total_ht = abs((
float) $amount_ht[$tva_tx]);
1199 $discount->total_tva = abs((
float) $amount_tva[$tva_tx]);
1200 $discount->total_localtax1 = abs((
float) $amount_localtax1[$tva_tx]);
1201 $discount->total_localtax2 = abs((
float) $amount_localtax2[$tva_tx]);
1202 $discount->total_ttc = abs((
float) $amount_ttc[$tva_tx]);
1203 $discount->multicurrency_amount_ht = abs((
float) $multicurrency_amount_ht[$tva_tx]);
1204 $discount->multicurrency_amount_tva = abs((
float) $multicurrency_amount_tva[$tva_tx]);
1205 $discount->multicurrency_amount_ttc = abs((
float) $multicurrency_amount_ttc[$tva_tx]);
1206 $discount->multicurrency_total_ht = abs((
float) $multicurrency_amount_ht[$tva_tx]);
1207 $discount->multicurrency_total_tva = abs((
float) $multicurrency_amount_tva[$tva_tx]);
1208 $discount->multicurrency_total_ttc = abs((
float) $multicurrency_amount_ttc[$tva_tx]);
1214 if (preg_match(
'/\((.*)\)/', $tva_tx, $reg)) {
1215 $vat_src_code = $reg[1];
1216 $tva_tx = preg_replace(
'/\s*\(.*\)/',
'', $tva_tx);
1219 $discount->tva_tx = abs((
float) $tva_tx);
1220 $discount->localtax1_tx = $taxes[
'localtax1'];
1221 $discount->localtax1_type = $taxes[
'localtax1_type'];
1222 $discount->localtax2_tx = $taxes[
'localtax2'];
1223 $discount->localtax2_type = $taxes[
'localtax2_type'];
1224 $discount->vat_src_code = $vat_src_code;
1226 $result = $discount->create($user);
1234 if (empty($error)) {
1244 $result =
$object->setPaid($user);
1258 } elseif ($action ==
'confirm_delete_paiement' && $confirm ==
'yes' && $usercanissuepayment) {
1263 $result = $paiement->fetch(
GETPOSTINT(
'paiement_id'));
1265 $result = $paiement->delete($user);
1267 header(
"Location: ".$_SERVER[
'PHP_SELF'].
"?id=".$id);
1275 } elseif ($action ==
'add' && $usercancreate) {
1282 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Type")),
null,
'errors');
1288 $object->demand_reason_id = $inputReasonId;
1291 $ret = $extrafields->setOptionalsFromPost(
null, $object);
1304 if (empty($dateinvoice)) {
1306 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Date")),
null,
'errors');
1316 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"ReplaceInvoice")),
null,
'errors');
1326 $object->date_pointoftax = $date_pointoftax;
1327 $object->note_public = trim(
GETPOST(
'note_public',
'restricthtml'));
1328 $object->note_private = trim(
GETPOST(
'note_private',
'restricthtml'));
1337 $object->location_incoterms =
GETPOST(
'location_incoterms',
'alpha');
1338 $object->multicurrency_code =
GETPOST(
'multicurrency_code',
'alpha');
1355 if (!($sourceinvoice > 0) && !
getDolGlobalString(
'INVOICE_CREDIT_NOTE_STANDALONE')) {
1357 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"InvoiceAvoirAskCombo")),
null,
'errors');
1361 if (empty($dateinvoice)) {
1363 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Date")),
null,
'errors');
1373 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"InvoiceSubtype")),
null,
'errors');
1378 if (!empty($originentity)) {
1379 $object->entity = $originentity;
1385 $object->date_pointoftax = $date_pointoftax;
1386 $object->note_public = trim(
GETPOST(
'note_public',
'restricthtml'));
1387 $object->note_private = trim(
GETPOST(
'note_private',
'restricthtml'));
1392 $object->cond_reglement_id = 0;
1396 $object->location_incoterms =
GETPOST(
'location_incoterms',
'alpha');
1397 $object->multicurrency_code =
GETPOST(
'multicurrency_code',
'alpha');
1401 $object->fk_facture_source = $sourceinvoice > 0 ? $sourceinvoice :
'';
1405 if (
$object->fk_facture_source > 0 && $facture_source->fetch(
$object->fk_facture_source) > 0) {
1406 if ($facture_source->isSituationInvoice()) {
1407 $object->situation_counter = $facture_source->situation_counter;
1408 $object->situation_cycle_ref = $facture_source->situation_cycle_ref;
1409 $facture_source->fetchPreviousNextSituationInvoice();
1412 $object->pos_source = $facture_source->pos_source;
1413 $object->module_source = $facture_source->module_source;
1421 if (
$object->copy_linked_contact($facture_source,
'internal') < 0) {
1423 } elseif ($facture_source->socid ==
$object->socid) {
1425 if (
$object->copy_linked_contact($facture_source,
'external') < 0) {
1436 if (
GETPOSTINT(
'invoiceAvoirWithLines') == 1 && $id > 0) {
1437 if (!empty($facture_source->lines)) {
1438 $fk_parent_line = 0;
1440 foreach ($facture_source->lines as $line) {
1442 if (method_exists($line,
'fetch_optionals')) {
1444 $line->fetch_optionals();
1448 if (($line->product_type != 9 && empty($line->fk_parent_line)) || $line->product_type == 9) {
1449 $fk_parent_line = 0;
1453 if ($facture_source->isSituationInvoice()) {
1454 $source_fk_prev_id = $line->fk_prev_id;
1455 $line->fk_prev_id = $line->id;
1457 if (!empty($facture_source->tab_previous_situation_invoice)) {
1460 $tab_jumped_credit_notes = array();
1461 $lineIndex = count($facture_source->tab_previous_situation_invoice) - 1;
1462 $searchPreviousInvoice =
true;
1463 while ($searchPreviousInvoice) {
1464 if ($facture_source->tab_previous_situation_invoice[$lineIndex]->type ==
Facture::TYPE_SITUATION || $lineIndex < 1) {
1465 $searchPreviousInvoice =
false;
1469 $tab_jumped_credit_notes[$lineIndex] = $facture_source->tab_previous_situation_invoice[$lineIndex]->id;
1475 $maxPrevSituationPercent = 0;
1476 foreach ($facture_source->tab_previous_situation_invoice[$lineIndex]->lines as $prevLine) {
1477 if ($prevLine->id == $source_fk_prev_id) {
1478 $maxPrevSituationPercent = max($maxPrevSituationPercent, $prevLine->situation_percent);
1481 $line->total_ht -= $prevLine->total_ht;
1482 $line->total_tva -= $prevLine->total_tva;
1483 $line->total_ttc -= $prevLine->total_ttc;
1484 $line->total_localtax1 -= $prevLine->total_localtax1;
1485 $line->total_localtax2 -= $prevLine->total_localtax2;
1487 $line->multicurrency_subprice -= $prevLine->multicurrency_subprice;
1488 $line->multicurrency_total_ht -= $prevLine->multicurrency_total_ht;
1489 $line->multicurrency_total_tva -= $prevLine->multicurrency_total_tva;
1490 $line->multicurrency_total_ttc -= $prevLine->multicurrency_total_ttc;
1495 $line->situation_percent = $maxPrevSituationPercent - $line->situation_percent;
1500 $maxPrevSituationPercent = 0;
1501 foreach ($tab_jumped_credit_notes as $index => $creditnoteid) {
1502 foreach ($facture_source->tab_previous_situation_invoice[$index]->lines as $prevLine) {
1503 if ($prevLine->fk_prev_id == $source_fk_prev_id) {
1504 $maxPrevSituationPercent = $prevLine->situation_percent;
1506 $line->total_ht -= $prevLine->total_ht;
1507 $line->total_tva -= $prevLine->total_tva;
1508 $line->total_ttc -= $prevLine->total_ttc;
1509 $line->total_localtax1 -= $prevLine->total_localtax1;
1510 $line->total_localtax2 -= $prevLine->total_localtax2;
1512 $line->multicurrency_subprice -= $prevLine->multicurrency_subprice;
1513 $line->multicurrency_total_ht -= $prevLine->multicurrency_total_ht;
1514 $line->multicurrency_total_tva -= $prevLine->multicurrency_total_tva;
1515 $line->multicurrency_total_ttc -= $prevLine->multicurrency_total_ttc;
1521 $line->situation_percent += $maxPrevSituationPercent;
1527 $line->fk_facture =
$object->id;
1528 $line->fk_parent_line = $fk_parent_line;
1530 $line->subprice = -$line->subprice;
1532 $line->total_ht = -$line->total_ht;
1533 $line->total_tva = -$line->total_tva;
1534 $line->total_ttc = -$line->total_ttc;
1535 $line->total_localtax1 = -$line->total_localtax1;
1536 $line->total_localtax2 = -$line->total_localtax2;
1538 $line->multicurrency_subprice = -$line->multicurrency_subprice;
1539 $line->multicurrency_total_ht = -$line->multicurrency_total_ht;
1540 $line->multicurrency_total_tva = -$line->multicurrency_total_tva;
1541 $line->multicurrency_total_ttc = -$line->multicurrency_total_ttc;
1543 $line->context[
'createcreditnotefrominvoice'] = 1;
1544 $result = $line->insert(0, 1);
1549 if ($result > 0 && $line->product_type == 9) {
1550 $fk_parent_line = $result;
1558 if (
GETPOSTINT(
'invoiceAvoirWithPaymentRestAmount') == 1 && $id > 0) {
1559 if ($facture_source->fetch(
$object->fk_facture_source) > 0) {
1560 $totalpaid = $facture_source->getSommePaiement();
1561 $totalcreditnotes = $facture_source->getSumCreditNotesUsed();
1562 $totaldeposits = $facture_source->getSumDepositsUsed();
1563 $remain_to_pay = abs($facture_source->total_ttc - $totalpaid - $totalcreditnotes - $totaldeposits);
1565 if (
getDolGlobalString(
'INVOICE_VAT_TO_USE_ON_CREDIT_NOTE_WHEN_GENERATED_FROM_REMAIN_TO_PAY') ==
'default') {
1566 if ((empty(
$object->thirdparty) || !is_object(
$object->thirdparty) || get_class(
$object->thirdparty) !=
'Societe')) {
1569 if (!empty(
$object->thirdparty) && is_object(
$object->thirdparty) && get_class(
$object->thirdparty) ==
'Societe') {
1574 } elseif ((
float)
getDolGlobalString(
'INVOICE_VAT_TO_USE_ON_CREDIT_NOTE_WHEN_GENERATED_FROM_REMAIN_TO_PAY') > 0) {
1575 $tva_tx = (float)
getDolGlobalString(
'INVOICE_VAT_TO_USE_ON_CREDIT_NOTE_WHEN_GENERATED_FROM_REMAIN_TO_PAY');
1580 $object->addline($langs->trans(
'invoiceAvoirLineWithPaymentRestAmount'), 0, 1, $tva_tx, 0, 0, 0, 0,
'',
'', 0, 0, 0,
'TTC', $remain_to_pay);
1585 if (!empty(
$object->fk_facture_source) &&
$id > 0) {
1586 $facture_source->fetch(
$object->fk_facture_source);
1587 $facture_source->fetchObjectLinked();
1589 if (!empty($facture_source->linkedObjectsIds)) {
1590 foreach ($facture_source->linkedObjectsIds as $sourcetype => $TIds) {
1591 $object->add_object_linked($sourcetype, current($TIds));
1600 if (empty($dateinvoice)) {
1602 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Date")),
null,
'errors');
1613 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"InvoiceSubtype")),
null,
'errors');
1623 $object->date_pointoftax = $date_pointoftax;
1624 $object->note_public = trim(
GETPOST(
'note_public',
'restricthtml'));
1625 $object->note_private = trim(
GETPOST(
'note_private',
'restricthtml'));
1636 $object->location_incoterms =
GETPOST(
'location_incoterms',
'alpha');
1637 $object->multicurrency_code =
GETPOST(
'multicurrency_code',
'alpha');
1653 $typeamount =
GETPOST(
'typedeposit',
'aZ09');
1654 $valuestandardinvoice =
price2num(str_replace(
'%',
'',
GETPOST(
'valuestandardinvoice',
'alpha')),
'MU');
1655 $valuedeposit =
price2num(str_replace(
'%',
'',
GETPOST(
'valuedeposit',
'alpha')),
'MU');
1659 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Customer")),
null,
'errors');
1663 if (empty($dateinvoice)) {
1665 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Date")),
null,
'errors');
1675 if ($valuestandardinvoice < 0 || $valuestandardinvoice > 100) {
1676 setEventMessages($langs->trans(
"ErrorAPercentIsRequired"),
null,
'errors');
1681 if ($typeamount && !empty($origin) && !empty($originid)) {
1682 if ($typeamount ==
'amount' && $valuedeposit <= 0) {
1683 setEventMessages($langs->trans(
"ErrorAnAmountWithoutTaxIsRequired"),
null,
'errors');
1687 if ($typeamount ==
'variable' && $valuedeposit <= 0) {
1688 setEventMessages($langs->trans(
"ErrorAPercentIsRequired"),
null,
'errors');
1692 if ($typeamount ==
'variablealllines' && $valuedeposit <= 0) {
1693 setEventMessages($langs->trans(
"ErrorAPercentIsRequired"),
null,
'errors');
1703 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"InvoiceSubtype")),
null,
'errors');
1713 $object->date_pointoftax = $date_pointoftax;
1714 $object->note_public = trim(
GETPOST(
'note_public',
'restricthtml'));
1715 $object->note_private = trim(
GETPOST(
'note_private',
'restricthtml'));
1725 $object->location_incoterms =
GETPOST(
'location_incoterms',
'alpha');
1726 $object->multicurrency_code =
GETPOST(
'multicurrency_code',
'alpha');
1730 $object->situation_counter = 1;
1735 if (in_array(
$object->type, $retainedWarrantyInvoiceAvailableType)) {
1737 $object->retained_warranty_fk_cond_reglement =
GETPOSTINT(
'retained_warranty_fk_cond_reglement');
1739 $object->retained_warranty = 0;
1740 $object->retained_warranty_fk_cond_reglement = 0;
1743 $retained_warranty_date_limit =
GETPOST(
'retained_warranty_date_limit');
1744 if (!empty($retained_warranty_date_limit) &&
dol_stringtotime($retained_warranty_date_limit)) {
1747 $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);
1752 if (!empty($origin) && !empty($originid)) {
1755 $element = $subelement = $origin;
1756 if (preg_match(
'/^([^_]+)_([^_]+)/i', $origin, $regs)) {
1757 $element = $regs[1];
1758 $subelement = $regs[2];
1762 if ($element ==
'order') {
1763 $element = $subelement =
'commande';
1765 if ($element ==
'propal') {
1766 $element =
'comm/propal';
1767 $subelement =
'propal';
1769 if ($element ==
'contract') {
1770 $element = $subelement =
'contrat';
1772 if ($element ==
'inter') {
1773 $element = $subelement =
'fichinter';
1775 if ($element ==
'shipping') {
1776 $element = $subelement =
'expedition';
1780 $object->origin_type = $origin;
1781 $object->origin_id = $originid;
1786 if (
$object->origin ==
'shipping') {
1787 require_once DOL_DOCUMENT_ROOT.
'/expedition/class/expedition.class.php';
1789 $exp->fetch(
$object->origin_id);
1790 $exp->fetchObjectLinked();
1791 if (is_array($exp->linkedObjectsIds[
'commande']) && count($exp->linkedObjectsIds[
'commande']) > 0) {
1792 foreach ($exp->linkedObjectsIds[
'commande'] as $key => $value) {
1793 $object->linked_objects[
'commande'] = $value;
1799 $object->linked_objects = array_merge(
$object->linked_objects,
GETPOST(
'other_linked_objects',
'array:int'));
1807 $classname = ucfirst($subelement);
1808 $srcobject =
new $classname(
$db);
1809 '@phan-var-force CommonObject $srcobject';
1811 dol_syslog(
"Try to find source object origin_type=".
$object->origin_type.
" origin_id=".
$object->origin_id.
" to add lines or deposit lines");
1812 $result = $srcobject->fetch(
$object->origin_id);
1818 $amountdeposit = array();
1821 if ($typeamount ==
'amount') {
1822 $amount = (float) $valuedeposit;
1824 $amount = $srcobject->total_ttc * ((float) $valuedeposit / 100);
1827 $TTotalByTva = array();
1828 foreach ($srcobject->lines as &$line) {
1829 if (empty($line->qty)) {
1832 if (!empty($line->special_code)) {
1835 $TTotalByTva[$line->tva_tx] += $line->total_ttc;
1837 '@phan-var-force array<string,float> $TTotalByTva';
1839 $amount_ttc_diff = 0.;
1840 foreach ($TTotalByTva as $tva => &$total) {
1841 if (empty($amountdeposit[$tva])) {
1842 $amountdeposit[$tva] = 0;
1844 $coef = $total / $srcobject->total_ttc;
1845 $am = $amount * $coef;
1846 $amount_ttc_diff += $am;
1847 $amountdeposit[$tva] += $am / (1 + (float) $tva / 100);
1850 if ($typeamount ==
'amount') {
1851 $amountdeposit[0] = $valuedeposit;
1852 } elseif ($typeamount ==
'variable') {
1855 $lines = $srcobject->lines;
1856 $numlines = count($lines);
1857 for ($i = 0; $i < $numlines; $i++) {
1859 if (empty($lines[$i]->qty)) {
1862 if (!empty($lines[$i]->special_code)) {
1866 $totalamount += $lines[$i]->total_ht;
1867 $tva_tx = $lines[$i]->tva_tx;
1869 if (empty($amountdeposit[$tva_tx])) {
1870 $amountdeposit[$tva_tx] = 0;
1872 $amountdeposit[$tva_tx] += ($lines[$i]->total_ht * (float) $valuedeposit) / 100;
1876 if ($totalamount == 0) {
1877 $amountdeposit[0] = 0;
1885 $amount_ttc_diff = $amountdeposit[0];
1888 foreach ($amountdeposit as $tva => $amount) {
1889 if (empty($amount)) {
1894 'amount' =>
'FixAmount',
1895 'variable' =>
'VarAmount'
1897 $descline =
'(DEPOSIT)';
1899 if ($typeamount ==
'amount') {
1900 $descline .=
' ('.price($valuedeposit, 0, $langs, 0, - 1, - 1, (!empty(
$object->multicurrency_code) ?
$object->multicurrency_code :
$conf->currency)).
')';
1901 } elseif ($typeamount ==
'variable') {
1902 $descline .=
' ('.$valuedeposit.
'%)';
1905 $descline .=
' - '.$srcobject->ref;
1918 $i >= 0 ? $lines[$i]->info_bits : 0,
1924 $i >= 0 ? $lines[$i]->special_code : 0,
1941 $diff =
$object->total_ttc - $amount_ttc_diff;
1945 $subprice_diff =
$object->lines[0]->subprice - $diff / (1 +
$object->lines[0]->tva_tx / 100);
1946 $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);
1955 $lines = $srcobject->lines;
1956 if (empty($lines) && method_exists($srcobject,
'fetch_lines')) {
1957 $srcobject->fetch_lines();
1958 $lines = $srcobject->lines;
1963 if (is_array($lines)) {
1964 foreach ($lines as $line) {
1966 $line->qty = (float)
price2num((
float) $line->qty * (float) $valuestandardinvoice / 100,
'MS');
1972 if (is_array($lines)) {
1973 foreach ($lines as $line) {
1975 $line->qty = (float)
price2num((
float) $line->qty * (float) $valuedeposit / 100,
'MS');
1980 $fk_parent_line = 0;
1981 $num = count($lines);
1983 for ($i = 0; $i < $num; $i++) {
1984 if (!in_array($lines[$i]->
id, $selectedLines)) {
1989 if ($srcobject->element ==
'shipping' &&
getDolGlobalString(
'SHIPMENT_GETS_ALL_ORDER_PRODUCTS') && $lines[$i]->qty == 0) {
1993 if (!isset(
$conf->global->CONTRACT_EXCLUDE_SERVICES_STATUS_FOR_INVOICE)) {
1994 $conf->global->CONTRACT_EXCLUDE_SERVICES_STATUS_FOR_INVOICE =
'5';
1996 if ($srcobject->element ==
'contrat' && in_array($lines[$i]->statut, explode(
',',
getDolGlobalString(
'CONTRACT_EXCLUDE_SERVICES_STATUS_FOR_INVOICE')))) {
2000 $label = (!empty($lines[$i]->label) ? $lines[$i]->label :
'');
2001 $desc = (!empty($lines[$i]->desc) ? $lines[$i]->desc :
'');
2003 if (
$object->situation_counter == 1) {
2004 $lines[$i]->situation_percent = 0;
2007 if ($lines[$i]->subprice < 0 && !
getDolGlobalString(
'INVOICE_KEEP_DISCOUNT_LINES_AS_IN_ORIGIN')) {
2010 $desc = $label ? $label : $langs->trans(
'Discount');
2014 $discount->fk_soc =
$object->socid;
2015 $discount->socid =
$object->socid;
2016 $discount->amount_ht = abs($lines[$i]->total_ht);
2017 $discount->amount_tva = abs($lines[$i]->total_tva);
2018 $discount->amount_ttc = abs($lines[$i]->total_ttc);
2019 $discount->total_ht = abs($lines[$i]->total_ht);
2020 $discount->total_tva = abs($lines[$i]->total_tva);
2021 $discount->total_ttc = abs($lines[$i]->total_ttc);
2022 $discount->tva_tx = $lines[$i]->tva_tx;
2023 $discount->localtax1_tx = $lines[$i]->localtax1_tx;
2024 $discount->localtax2_tx = $lines[$i]->localtax2_tx;
2025 $discount->localtax1_type = $lines[$i]->localtax1_type;
2026 $discount->localtax2_type = $lines[$i]->localtax2_type;
2027 $discount->total_localtax1 = abs($lines[$i]->total_localtax1);
2028 $discount->total_localtax2 = abs($lines[$i]->total_localtax2);
2029 $discount->fk_user = $user->id;
2030 $discount->description = $desc;
2031 $discount->multicurrency_subprice = abs($lines[$i]->multicurrency_subprice);
2032 $discount->multicurrency_amount_ht = abs($lines[$i]->multicurrency_total_ht);
2033 $discount->multicurrency_amount_tva = abs($lines[$i]->multicurrency_total_tva);
2034 $discount->multicurrency_amount_ttc = abs($lines[$i]->multicurrency_total_ttc);
2035 $discount->multicurrency_total_ht = abs($lines[$i]->multicurrency_total_ht);
2036 $discount->multicurrency_total_tva = abs($lines[$i]->multicurrency_total_tva);
2037 $discount->multicurrency_total_ttc = abs($lines[$i]->multicurrency_total_ttc);
2039 $discountid = $discount->create($user);
2040 if ($discountid > 0) {
2041 $result =
$object->insert_discount($discountid);
2054 if (isset($lines[$i]->date_debut_prevue)) {
2057 if (isset($lines[$i]->date_debut_reel)) {
2060 if (isset($lines[$i]->date_start)) {
2066 if (isset($lines[$i]->date_fin_prevue)) {
2067 $date_end = $lines[$i]->date_fin_prevue;
2069 if (isset($lines[$i]->date_fin_reel)) {
2070 $date_end = $lines[$i]->date_fin_reel;
2072 if (isset($lines[$i]->date_end)) {
2073 $date_end = $lines[$i]->date_end;
2077 if (($lines[$i]->product_type != 9 && empty($lines[$i]->fk_parent_line)) || $lines[$i]->product_type == 9) {
2078 $fk_parent_line = 0;
2081 $array_options = array();
2083 if (method_exists($lines[$i],
'fetch_optionals')) {
2084 $lines[$i]->fetch_optionals();
2085 $array_options = $lines[$i]->array_options;
2088 $tva_tx = $lines[$i]->tva_tx;
2089 if (!empty($lines[$i]->vat_src_code) && !preg_match(
'/\(/', (
string) $tva_tx)) {
2090 $tva_tx .=
' ('.$lines[$i]->vat_src_code.
')';
2100 $lines[$i]->subprice,
2105 $lines[$i]->fk_product,
2106 $lines[$i]->remise_percent,
2110 (
int) $lines[$i]->info_bits,
2111 isset($lines[$i]->fk_remise_except) ? $lines[$i]->fk_remise_except : null,
2116 $lines[$i]->special_code,
2120 isset($lines[$i]->fk_fournprice) ? $lines[$i]->fk_fournprice : null,
2124 $lines[$i]->situation_percent ?? 100,
2125 $lines[$i]->fk_prev_id ?? 0,
2126 $lines[$i]->fk_unit,
2133 foreach (
$object->lines as $line) {
2134 if ($line->id == $result) {
2135 $line->extraparams = $lines[$i]->extraparams;
2136 $line->setExtraParameters();
2148 if ($result > 0 && $lines[$i]->product_type == 9) {
2149 $fk_parent_line = $result;
2161 $object->line_order(
true,
'DESC');
2189 $parameters = array(
'origin_type' =>
$object->origin_type,
'origin_id' =>
$object->origin_id,
'objFrom' => $srcobject);
2190 $reshook = $hookmanager->executeHooks(
'createFrom', $parameters, $object, $action);
2203 for ($i = 1; $i <= $NBLINES; $i++) {
2209 $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);
2220 if (empty($dateinvoice)) {
2222 $mesg = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Date"));
2232 $mesg = $langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"InvoiceSituation"));
2242 if (!empty($origin) && !empty($originid)) {
2243 include_once DOL_DOCUMENT_ROOT.
'/core/lib/price.lib.php';
2246 $object->origin_type = $origin;
2247 $object->origin_id = $originid;
2251 $retained_warranty =
GETPOSTINT(
'retained_warranty');
2252 if (
price2num($retained_warranty) > 0) {
2256 if (
GETPOSTINT(
'retained_warranty_fk_cond_reglement') > 0) {
2257 $object->retained_warranty_fk_cond_reglement =
GETPOSTINT(
'retained_warranty_fk_cond_reglement');
2260 $retained_warranty_date_limit =
GETPOST(
'retained_warranty_date_limit');
2261 if (!empty($retained_warranty_date_limit) &&
$db->jdate($retained_warranty_date_limit)) {
2262 $object->retained_warranty_date_limit =
$db->jdate($retained_warranty_date_limit);
2264 $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);
2267 foreach (
$object->lines as $i => &$line) {
2268 $line->fk_prev_id = $line->id;
2269 $line->fetch_optionals();
2271 $line->situation_percent = 0;
2273 $line->situation_percent = $line->get_prev_progress(
$object->id);
2277 $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);
2278 $line->total_ht = (float) $tabprice[0];
2279 $line->total_tva = (float) $tabprice[1];
2280 $line->total_ttc = (float) $tabprice[2];
2281 $line->total_localtax1 = (float) $tabprice[9];
2282 $line->total_localtax2 = (float) $tabprice[10];
2283 $line->multicurrency_total_ht = (float) $tabprice[16];
2284 $line->multicurrency_total_tva = (float) $tabprice[17];
2285 $line->multicurrency_total_ttc = (float) $tabprice[18];
2288 if ($line->fk_remise_except) {
2290 $result = $discount->fetch($line->fk_remise_except);
2293 if ($discount->fk_facture_line > 0) {
2294 $line->fk_remise_except = 0;
2303 $object->date_pointoftax = $date_pointoftax;
2304 $object->note_public = trim(
GETPOST(
'note_public',
'restricthtml'));
2318 $object->situation_counter += 1;
2325 $nextSituationInvoice->fetch($id);
2328 $extrafields->fetch_name_optionals_label($nextSituationInvoice->table_element);
2329 $ret = $extrafields->setOptionalsFromPost(
null, $nextSituationInvoice);
2331 $nextSituationInvoice->insertExtraFields();
2335 $parameters = array(
'origin_type' =>
$object->origin_type,
'origin_id' =>
$object->origin_id);
2336 $reshook = $hookmanager->executeHooks(
'createFrom', $parameters, $nextSituationInvoice, $action);
2347 if ($id > 0 && !$error) {
2349 $categories =
GETPOST(
'categories',
'array');
2350 if (method_exists($object,
'setCategories')) {
2351 $object->setCategories($categories);
2359 $outputlangs = $langs;
2362 $newlang =
GETPOST(
'lang_id',
'aZ09');
2365 if (empty(
$object->thirdparty)) {
2368 $newlang =
$object->thirdparty->default_lang;
2370 if (!empty($newlang)) {
2372 $outputlangs->setDefaultLang($newlang);
2373 $outputlangs->load(
'products');
2378 $result =
$object->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
2384 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
2389 $_GET[
"origin"] =
GETPOST(
"origin",
'alpha');
2393 } elseif ($action ==
'addline' &&
GETPOST(
'submitforalllines',
'aZ09') && (
GETPOST(
'alldate_start',
'alpha') ||
GETPOST(
'alldate_end',
'alpha')) && $usercancreate) {
2397 foreach (
$object->lines as $line) {
2398 if ($line->special_code == SUBTOTALS_SPECIAL_CODE) {
2401 if ($line->product_type == 1) {
2402 $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);
2405 } elseif ($action ==
'addline' &&
GETPOST(
'submitforalllines',
'alpha') &&
GETPOST(
'vatforalllines',
'alpha') !==
'' && $usercancreate) {
2407 $vat_rate = (
GETPOST(
'vatforalllines') ?
GETPOST(
'vatforalllines') : 0);
2408 $vat_rate = str_replace(
'*',
'', $vat_rate);
2411 foreach (
$object->lines as $line) {
2412 if ($line->special_code == SUBTOTALS_SPECIAL_CODE) {
2415 $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);
2417 } elseif ($action ==
'addline' &&
GETPOST(
'submitforalllines',
'alpha') &&
GETPOST(
'remiseforalllines',
'alpha') !==
'' && $usercancreate) {
2419 $remise_percent = (
GETPOST(
'remiseforalllines') ?
GETPOST(
'remiseforalllines') : 0);
2420 $remise_percent = str_replace(
'*',
'', $remise_percent);
2421 foreach (
$object->lines as $line) {
2422 if ($line->special_code == SUBTOTALS_SPECIAL_CODE) {
2425 $tvatx = $line->tva_tx;
2426 if (!empty($line->vat_src_code)) {
2427 $tvatx .=
' ('.$line->vat_src_code.
')';
2429 $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);
2431 } elseif ($action ==
'confirm_addtitleline' && $usercancreate) {
2434 $langs->load(
'subtotals');
2436 $desc =
GETPOST(
'subtotallinedesc',
'alphanohtml');
2437 $depth =
GETPOSTINT(
'subtotallinelevel') ?? 1;
2439 $subtotal_options = array();
2441 foreach (Facture::$TITLE_OPTIONS as $option) {
2442 $value =
GETPOST($option,
'alphanohtml');
2444 $subtotal_options[$option] = $value ==
'on' ? 1 : $value;
2449 $result =
$object->addSubtotalLine($langs, $desc, (
int) $depth, $subtotal_options);
2460 $outputlangs = $langs;
2461 $newlang =
GETPOST(
'lang_id',
'alpha');
2463 $newlang =
$object->thirdparty->default_lang;
2465 if (!empty($newlang)) {
2467 $outputlangs->setDefaultLang($newlang);
2470 $object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
2475 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
2477 } elseif ($action ==
'confirm_addsubtotalline' && $usercancreate) {
2480 $langs->load(
'subtotals');
2482 $choosen_line =
GETPOST(
'subtotaltitleline',
'alphanohtml');
2483 foreach (
$object->lines as $line) {
2484 if ($line->desc == $choosen_line && $line->special_code == SUBTOTALS_SPECIAL_CODE) {
2485 $desc = $line->desc;
2486 $depth = -$line->qty;
2490 $subtotal_options = array();
2492 foreach (Facture::$SUBTOTAL_OPTIONS as $option) {
2493 $value =
GETPOST($option,
'alphanohtml');
2495 $subtotal_options[$option] = $value ==
'on' ? 1 : $value;
2500 if (isset($desc) && isset($depth)) {
2501 $result =
$object->addSubtotalLine($langs, $desc, (
int) $depth, $subtotal_options);
2504 $object->errors[] = $langs->trans(
"CorrespondingTitleNotFound");
2513 $outputlangs = $langs;
2514 $newlang =
GETPOST(
'lang_id',
'alpha');
2516 $newlang =
$object->thirdparty->default_lang;
2518 if (!empty($newlang)) {
2520 $outputlangs->setDefaultLang($newlang);
2523 $object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
2528 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
2530 } elseif ($action ==
'addline' &&
GETPOST(
'updateallvatlinesblock',
'alpha') &&
GETPOST(
'vatforblocklines',
'alpha') !==
'' && $usercancreate) {
2531 $tx_tva =
GETPOST(
'vatforblocklines') ?
GETPOST(
'vatforblocklines') : 0;
2532 $object->updateSubtotalLineBlockLines($langs,
$object->getRangOfLine($lineid),
'tva', $tx_tva);
2533 } elseif ($action ==
'addline' &&
GETPOST(
'updatealldiscountlinesblock',
'alpha') &&
GETPOST(
'discountforblocklines',
'alpha') !==
'' && $usercancreate) {
2534 $discount =
GETPOST(
'discountforblocklines') ?
GETPOST(
'discountforblocklines') : 0;
2535 $object->updateSubtotalLineBlockLines($langs,
$object->getRangOfLine($lineid),
'discount', $discount);
2536 } elseif ($action ==
'addline' && !
GETPOST(
'submitforalllines',
'alpha') && !
GETPOST(
'submitforallmargins',
'alpha') && !
GETPOST(
'submitforallmark',
'alpha') && $usercancreate) {
2537 $langs->load(
'errors');
2542 $line_desc = (GETPOSTISSET(
'dp_desc') ?
GETPOST(
'dp_desc',
'restricthtml') :
'');
2545 $price_ht_devise =
'';
2547 $price_ttc_devise =
'';
2550 $price_min_ttc =
'';
2552 if (
GETPOST(
'price_ht') !==
'') {
2555 if (
GETPOST(
'multicurrency_price_ht') !==
'') {
2558 if (
GETPOST(
'price_ttc') !==
'') {
2561 if (
GETPOST(
'multicurrency_price_ttc') !==
'') {
2562 $price_ttc_devise =
price2num(
GETPOST(
'multicurrency_price_ttc'),
'CU', 2);
2565 $prod_entry_mode =
GETPOST(
'prod_entry_mode',
'aZ09');
2566 if ($prod_entry_mode ==
'free') {
2572 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"ProductOrService")),
null,
'errors');
2577 $tva_tx =
GETPOST(
'tva_tx',
'alpha');
2580 $remise_percent = (GETPOSTISSET(
'remise_percent'.$predef) ?
price2num(
GETPOST(
'remise_percent'.$predef,
'alpha'),
'', 2) : 0);
2581 if (empty($remise_percent)) {
2582 $remise_percent = 0;
2586 $extralabelsline = $extrafields->fetch_name_optionals_label(
$object->table_element_line);
2587 $array_options = $extrafields->getOptionalsFromPost(
$object->table_element_line, $predef);
2589 if (is_array($extralabelsline)) {
2591 foreach ($extralabelsline as $key => $value) {
2592 unset($_POST[
"options_".$key.$predef]);
2596 if ((empty($idprod) || $idprod < 0) && ($price_ht < 0) && ($qty < 0)) {
2597 setEventMessages($langs->trans(
'ErrorBothFieldCantBeNegative', $langs->transnoentitiesnoconv(
'UnitPriceHT'), $langs->transnoentitiesnoconv(
'Qty')),
null,
'errors');
2600 if (!$prod_entry_mode) {
2602 setEventMessages($langs->trans(
'ErrorChooseBetweenFreeEntryOrPredefinedProduct'),
null,
'errors');
2606 if ($prod_entry_mode ==
'free' && (empty($idprod) || $idprod < 0) &&
GETPOST(
'type') < 0) {
2607 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'Type')),
null,
'errors');
2612 if ($prod_entry_mode ==
'free' && (empty($idprod) || $idprod < 0)
2613 && (((
float) $price_ht < 0 && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES')) || $price_ht ===
'')
2614 && (((
float) $price_ht_devise < 0 && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES')) || $price_ht_devise ===
'')
2615 && ((
float) $price_ttc < 0 && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES') || $price_ttc ===
'')
2616 && ((
float) $price_ttc_devise < 0 && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES') || $price_ttc_devise ===
'')
2617 &&
$object->type != $object::TYPE_CREDIT_NOTE) {
2618 if (((
float) $price_ht < 0 || (
float) $price_ttc < 0) && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES')) {
2619 $langs->load(
"errors");
2620 if (
$object->type == $object::TYPE_DEPOSIT) {
2622 setEventMessages($langs->trans(
"ErrorLinesCantBeNegativeOnDeposits"),
null,
'errors');
2624 setEventMessages($langs->trans(
"ErrorFieldCantBeNegativeOnInvoice", $langs->transnoentitiesnoconv(
"UnitPriceHT"), $langs->transnoentitiesnoconv(
"CustomerAbsoluteDiscountShort")),
null,
'errors');
2629 if ($prod_entry_mode ==
'free' && (empty($idprod) || $idprod < 0) &&
GETPOST(
'price_ht') ===
'' &&
GETPOST(
'price_ttc') ===
'' && $price_ht_devise ===
'') {
2630 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'UnitPrice')),
null,
'errors');
2634 if ($prod_entry_mode ==
'free' && (empty($idprod) || $idprod < 0) && empty($line_desc)) {
2635 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'Description')),
null,
'errors');
2639 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'Qty')),
null,
'errors');
2643 $langs->load(
"errors");
2644 setEventMessages($langs->trans(
'ErrorQtyForCustomerInvoiceCantBeNegative'),
null,
'errors');
2648 if (!$error &&
isModEnabled(
'variants') && $prod_entry_mode !=
'free') {
2649 if ($combinations =
GETPOST(
'combinations',
'array:alphanohtml')) {
2653 if ($res = $prodcomb->fetchByProductCombination2ValuePairs($idprod, $combinations)) {
2654 $idprod = $res->fk_product_child;
2656 setEventMessages($langs->trans(
'ErrorProductCombinationNotFound'),
null,
'errors');
2662 $price_base_type =
null;
2663 if (!$error && (!empty($line_desc) || (!empty($idprod) && $idprod > 0))) {
2669 $ret =
$object->fetch_thirdparty();
2674 $price_base_type = (
GETPOST(
'price_base_type',
'alpha') ?
GETPOST(
'price_base_type',
'alpha') :
'HT');
2685 if (!empty($idprod) && $idprod > 0) {
2687 $prod->fetch($idprod);
2696 $pu_ht = $datapriceofproduct[
'pu_ht'];
2697 $pu_ttc = $datapriceofproduct[
'pu_ttc'];
2698 $price_min = $datapriceofproduct[
'price_min'];
2699 $price_min_ttc = (isset($datapriceofproduct[
'price_min_ttc'])) ? $datapriceofproduct[
'price_min_ttc'] : null;
2700 $price_base_type = empty($datapriceofproduct[
'price_base_type']) ?
'HT' : $datapriceofproduct[
'price_base_type'];
2704 $tmpvat = (float)
price2num(preg_replace(
'/\s*\(.*\)/',
'', $tva_tx));
2705 $tmpprodvat =
price2num(preg_replace(
'/\s*\(.*\)/',
'', (
string)
$prod->tva_tx));
2709 if (!empty($price_ht) || $price_ht ===
'0') {
2711 $pu_ttc =
price2num((
float) $pu_ht * (1 + ($tmpvat / 100)),
'MU');
2712 } elseif (!empty($price_ht_devise) || $price_ht_devise ===
'0') {
2713 $pu_ht_devise =
price2num($price_ht_devise,
'MU');
2714 $pu_ttc_devise = (float)
price2num((
float) $pu_ht_devise * (1 + ((float) $tmpvat / 100)),
'MU');
2717 } elseif (!empty($price_ttc) || $price_ttc ===
'0') {
2719 $pu_ht =
price2num((
float) $pu_ttc / (1 + ($tmpvat / 100)),
'MU');
2720 } elseif (!empty($price_ttc_devise) || (
string) $price_ttc_devise ===
'0') {
2721 $pu_ttc_devise = (float)
price2num($price_ttc_devise,
'MU');
2722 $pu_ht_devise = (float)
price2num((
float) $pu_ttc_devise / (1 + ((float) $tmpvat / 100)),
'MU');
2725 } elseif ($tmpvat != $tmpprodvat) {
2727 if ($price_base_type !=
'HT') {
2728 $pu_ht =
price2num($pu_ttc / (1 + ($tmpvat / 100)),
'MU');
2730 $pu_ttc =
price2num($pu_ht * (1 + ($tmpvat / 100)),
'MU');
2734 $outputlangs = $langs;
2740 if (
GETPOST(
'lang_id',
'aZ09')) {
2741 $newlang =
GETPOST(
'lang_id',
'aZ09');
2743 if (empty($newlang)) {
2744 $newlang =
$object->thirdparty->default_lang;
2746 if (!empty($newlang)) {
2748 $outputlangs->setDefaultLang($newlang);
2749 $outputlangs->load(
'products');
2752 $desc = (!empty(
$prod->multilangs [$outputlangs->defaultlang] [
"description"])) ?
$prod->multilangs [$outputlangs->defaultlang] [
"description"] :
$prod->
description;
2754 $desc =
$prod->description;
2770 if (!empty(
$prod->customcode)) {
2771 $tmptxt .= $outputlangs->transnoentitiesnoconv(
"CustomsCode").
': '.
$prod->customcode;
2773 if (!empty(
$prod->customcode) && !empty(
$prod->country_code)) {
2776 if (!empty(
$prod->country_code)) {
2777 $tmptxt .= $outputlangs->transnoentitiesnoconv(
"CountryOrigin").
': '.
getCountry(
$prod->country_code,
'',
$db, $outputlangs, 0);
2780 if (!empty(
$prod->customcode)) {
2781 $tmptxt .= $langs->transnoentitiesnoconv(
"CustomsCode").
': '.
$prod->customcode;
2783 if (!empty(
$prod->customcode) && !empty(
$prod->country_code)) {
2786 if (!empty(
$prod->country_code)) {
2787 $tmptxt .= $langs->transnoentitiesnoconv(
"CountryOrigin").
': '.
getCountry(
$prod->country_code,
'',
$db, $langs, 0);
2794 $type =
$prod->type;
2795 $fk_unit =
$prod->fk_unit;
2797 if (!empty($price_ht)) {
2802 if (!empty($price_ttc)) {
2807 $tva_npr = (preg_match(
'/\*/', $tva_tx) ? 1 : 0);
2808 $tva_tx = str_replace(
'*',
'', $tva_tx);
2809 if (empty($tva_tx)) {
2812 $label = (
GETPOST(
'product_label') ?
GETPOST(
'product_label') :
'');
2815 $fk_unit =
GETPOST(
'units',
'alpha');
2817 if ($pu_ttc && !$pu_ht) {
2818 $price_base_type =
'TTC';
2832 $pu_ht_devise =
price2num($price_ht_devise,
'', 2);
2833 $pu_ttc_devise =
price2num($price_ttc_devise,
'', 2);
2836 $pu_equivalent = $pu_ht;
2837 $pu_equivalent_ttc = $pu_ttc;
2839 $currency_tx =
$object->multicurrency_tx;
2843 if ($pu_ht ==
'' && $pu_ht_devise !=
'' && $currency_tx !=
'' && !empty((
float) $currency_tx)) {
2844 $pu_equivalent = (float) $pu_ht_devise / (
float) $currency_tx;
2846 if ($pu_ttc ==
'' && $pu_ttc_devise !=
'' && $currency_tx !=
'' && !empty((
float) $currency_tx)) {
2847 $pu_equivalent_ttc = (float) $pu_ttc_devise / (
float) $currency_tx;
2862 $fournprice = (int) (
GETPOST(
'fournprice'.$predef) ?
GETPOST(
'fournprice'.$predef) :
'');
2867 $price2num_remise_percent =
price2num($remise_percent);
2868 $price2num_price_min =
price2num($price_min);
2869 $price2num_price_min_ttc =
price2num($price_min_ttc);
2870 if (empty($price2num_pu_ht)) {
2871 $price2num_pu_ht = 0;
2873 if (empty($price2num_remise_percent)) {
2874 $price2num_remise_percent = 0;
2876 if (empty($price2num_price_min)) {
2877 $price2num_price_min = 0;
2879 if (empty($price2num_price_min_ttc)) {
2880 $price2num_price_min_ttc = 0;
2885 if ($pu_equivalent && $price_min && (((
float)
price2num($pu_equivalent) * (1 - $remise_percent / 100)) < (
float)
price2num($price_min)) && $price_base_type ==
'HT') {
2886 $mesg = $langs->trans(
"CantBeLessThanMinPrice",
price(
price2num($price_min,
'MU'), 0, $langs, 0, 0, -1,
$conf->currency));
2889 } 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') {
2890 $mesg = $langs->trans(
"CantBeLessThanMinPriceInclTax",
price(
price2num($price_min_ttc,
'MU'), 0, $langs, 0, 0, -1,
$conf->currency));
2909 $situation_percent = (GETPOSTISSET(
'progress') ?
GETPOSTINT(
'progress') : 100);
2911 $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);
2917 $outputlangs = $langs;
2920 $newlang =
GETPOST(
'lang_id',
'aZ09');
2923 $newlang =
$object->thirdparty->default_lang;
2925 if (!empty($newlang)) {
2927 $outputlangs->setDefaultLang($newlang);
2928 $outputlangs->load(
'products');
2931 $result =
$object->generateDocument($model, $outputlangs, $hidedetails, $hidedesc, $hideref);
2937 unset($_POST[
'prod_entry_mode']);
2938 unset($_POST[
'qty']);
2939 unset($_POST[
'type']);
2940 unset($_POST[
'remise_percent']);
2941 unset($_POST[
'price_ht']);
2942 unset($_POST[
'multicurrency_price_ht']);
2943 unset($_POST[
'price_ttc']);
2944 unset($_POST[
'tva_tx']);
2945 unset($_POST[
'product_ref']);
2946 unset($_POST[
'product_label']);
2947 unset($_POST[
'product_desc']);
2948 unset($_POST[
'fournprice']);
2949 unset($_POST[
'buying_price']);
2950 unset($_POST[
'np_marginRate']);
2951 unset($_POST[
'np_markRate']);
2952 unset($_POST[
'dp_desc']);
2953 unset($_POST[
'idprod']);
2954 unset($_POST[
'units']);
2955 unset($_POST[
'date_starthour']);
2956 unset($_POST[
'date_startmin']);
2957 unset($_POST[
'date_startsec']);
2958 unset($_POST[
'date_startday']);
2959 unset($_POST[
'date_startmonth']);
2960 unset($_POST[
'date_startyear']);
2961 unset($_POST[
'date_endhour']);
2962 unset($_POST[
'date_endmin']);
2963 unset($_POST[
'date_endsec']);
2964 unset($_POST[
'date_endday']);
2965 unset($_POST[
'date_endmonth']);
2966 unset($_POST[
'date_endyear']);
2967 unset($_POST[
'situations']);
2968 unset($_POST[
'progress']);
2976 } elseif ($action ==
'addline' && $usercancreate && (
2977 (
GETPOST(
'submitforallmargins',
'alpha') &&
GETPOST(
'marginforalllines',
'alpha') !==
'') ||
2978 (
GETPOST(
'submitforallmark',
'alpha') &&
GETPOST(
'markforalllines',
'alpha') !==
'')
2981 $margin_rate = GETPOSTISSET(
'marginforalllines') ?
GETPOST(
'marginforalllines',
'int') :
'';
2982 $mark_rate = GETPOSTISSET(
'markforalllines') ?
GETPOST(
'markforalllines',
'int') :
'';
2983 foreach (
$object->lines as &$line) {
2984 if ($line->subprice > 0) {
2985 if ($line->special_code == SUBTOTALS_SPECIAL_CODE) {
2988 $subprice_multicurrency = $line->subprice;
2989 if (is_numeric($margin_rate) && $margin_rate > 0) {
2990 $line->subprice = (float)
price2num((
float) $line->pa_ht * (1 + (float) $margin_rate / 100),
'MU');
2991 } elseif (is_numeric($mark_rate) && $mark_rate > 0) {
2992 $line->subprice = (float) ($line->pa_ht / (1 - ((
float) $mark_rate / 100)));
2994 $line->subprice = (float) $line->pa_ht;
2998 $res =
$prod->fetch($line->fk_product);
3000 if (
$prod->price_min > $line->subprice) {
3001 $price_subprice =
price($line->subprice, 0, $outlangs, 1, -1, -1,
'auto');
3002 $price_price_min =
price(
$prod->price_min, 0, $outlangs, 1, -1, -1,
'auto');
3003 setEventMessages(
$prod->ref .
' - ' .
$prod->label .
' (' . $price_subprice .
' < ' . $price_price_min .
' ' . strtolower($langs->trans(
"MinPrice")) .
')' .
"\n",
null,
'warnings');
3011 $multicurrency_subprice = (float) $line->subprice * $line->multicurrency_subprice / $subprice_multicurrency;
3013 $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);
3016 if (is_numeric($margin_rate) && empty($mark_rate)) {
3017 $line->marge_tx = $margin_rate;
3018 } elseif (is_numeric($mark_rate) && empty($margin_rate)) {
3019 $line->marque_tx = $mark_rate;
3021 $line->total_ht = $line->qty * (float) $line->subprice;
3022 $line->total_tva = $line->tva_tx * $line->qty * (float) $line->subprice;
3023 $line->total_ttc = (1 + $line->tva_tx) * $line->qty * (
float) $line->subprice;
3025 $line->multicurrency_total_ht = $line->qty * (float) $subprice_multicurrency * $line->multicurrency_subprice / $line->subprice;
3026 $line->multicurrency_total_tva = $line->tva_tx * $line->qty * (float) $subprice_multicurrency * $line->multicurrency_subprice / $line->subprice;
3027 $line->multicurrency_total_ttc = (1 + $line->tva_tx) * $line->qty * (
float) $subprice_multicurrency * $line->multicurrency_subprice / $line->subprice;
3029 $line->multicurrency_subprice = $multicurrency_subprice;
3035 } elseif ($action ==
'updatetitleline' && GETPOSTISSET(
"save") && $usercancreate && !
GETPOST(
'cancel',
'alpha')) {
3038 $langs->load(
'subtotals');
3040 $desc =
GETPOST(
'line_desc',
'alphanohtml') ?? $langs->trans(
"Title");
3043 $subtotal_options = array();
3045 foreach (Facture::$TITLE_OPTIONS as $option) {
3046 $value =
GETPOST($option,
'alphanohtml');
3048 $subtotal_options[$option] = $value ==
'on' ? 1 : $value;
3053 $result =
$object->updateSubtotalLine($langs,
GETPOSTINT(
'lineid'), $desc, $depth, $subtotal_options);
3064 $outputlangs = $langs;
3065 $newlang =
GETPOST(
'lang_id',
'alpha');
3067 $newlang =
$object->thirdparty->default_lang;
3069 if (!empty($newlang)) {
3071 $outputlangs->setDefaultLang($newlang);
3074 $object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
3079 } elseif ($action ==
'updatesubtotalline' && GETPOSTISSET(
"save") && $usercancreate && !
GETPOST(
'cancel',
'alpha')) {
3082 $langs->load(
'subtotals');
3084 $desc =
GETPOST(
'line_desc',
'alphanohtml');
3087 $subtotal_options = array();
3089 foreach (Facture::$SUBTOTAL_OPTIONS as $option) {
3090 $value =
GETPOST($option,
'alphanohtml');
3092 $subtotal_options[$option] = $value ==
'on' ? 1 : $value;
3097 $result =
$object->updateSubtotalLine($langs,
GETPOSTINT(
'lineid'), $desc, $depth, $subtotal_options);
3105 $outputlangs = $langs;
3106 $newlang =
GETPOST(
'lang_id',
'alpha');
3108 $newlang =
$object->thirdparty->default_lang;
3110 if (!empty($newlang)) {
3112 $outputlangs->setDefaultLang($newlang);
3115 $object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
3120 } elseif ($action ==
'updateline' && $usercancreate && !
GETPOST(
'cancel',
'alpha')) {
3121 if (!
$object->fetch($id) > 0) {
3144 if (preg_match(
'/\*/', $vat_rate)) {
3149 $vat_rate = str_replace(
'*',
'', $vat_rate);
3154 $fournprice = (int) (
GETPOST(
'fournprice') ?
GETPOST(
'fournprice') :
'');
3158 $pu_equivalent = $pu_ht;
3159 $pu_equivalent_ttc = $pu_ttc;
3161 $currency_tx =
$object->multicurrency_tx;
3165 if ($pu_ht ==
'' && $pu_ht_devise !=
'' && $currency_tx !=
'' && !empty((
float) $currency_tx)) {
3166 $pu_equivalent = (float) $pu_ht_devise / (
float) $currency_tx;
3168 if ($pu_ttc ==
'' && $pu_ttc_devise !=
'' && $currency_tx !=
'' && !empty((
float) $currency_tx)) {
3169 $pu_equivalent_ttc = (float) $pu_ttc_devise / (
float) $currency_tx;
3184 $extralabelsline = $extrafields->fetch_name_optionals_label(
$object->table_element_line);
3185 $array_options = $extrafields->getOptionalsFromPost(
$object->table_element_line);
3187 if (is_array($extralabelsline)) {
3189 foreach ($extralabelsline as $key => $value) {
3190 unset($_POST[
"options_".$key]);
3196 if ($special_code == 3) {
3202 $percent = $line->get_prev_progress(
$object->id);
3207 if ($progress >= 0) {
3208 $mesg = $langs->trans(
"CantBeNullOrPositive");
3212 } elseif ($progress < $line->situation_percent) {
3213 $mesg = $langs->trans(
"CantBeLessThanMinPercent");
3217 } elseif ($progress < $percent) {
3218 $mesg =
'<div class="warning">'.$langs->trans(
"CantBeLessThanMinPercent").
'</div>';
3226 if (empty($remise_percent)) {
3227 $remise_percent = 0;
3230 $price_base_type =
'HT';
3232 if (empty($pu) && !empty($pu_ttc)) {
3234 $price_base_type =
'TTC';
3239 if (!empty($productid)) {
3241 $product->fetch($productid);
3243 $type = $product->type;
3245 $price_min = $product->price_min;
3247 $price_min = $product->multiprices_min[
$object->thirdparty->price_level];
3249 $price_min_ttc = $product->price_min_ttc;
3251 $price_min_ttc = $product->multiprices_min_ttc[
$object->thirdparty->price_level];
3258 if ($pu_equivalent && $price_min && (((
float)
price2num($pu_equivalent) * (1 - (
float) $remise_percent / 100)) < (float)
price2num($price_min)) && $price_base_type ==
'HT') {
3259 $mesg = $langs->trans(
"CantBeLessThanMinPrice",
price(
price2num($price_min,
'MU'), 0, $langs, 0, 0, -1,
$conf->currency));
3262 $action =
'editline';
3263 } 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') {
3264 $mesg = $langs->trans(
"CantBeLessThanMinPriceInclTax",
price(
price2num($price_min_ttc,
'MU'), 0, $langs, 0, 0, -1,
$conf->currency));
3267 $action =
'editline';
3272 $label = (
GETPOST(
'product_label') ?
GETPOST(
'product_label') :
'');
3276 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Type")),
null,
'errors');
3281 $langs->load(
"errors");
3282 setEventMessages($langs->trans(
'ErrorQtyForCustomerInvoiceCantBeNegative'),
null,
'errors');
3286 if (($pu_ht < 0 || $pu_ttc < 0) && !
getDolGlobalString(
'FACTURE_ENABLE_NEGATIVE_LINES')) {
3287 $langs->load(
"errors");
3288 if (
$object->type == $object::TYPE_DEPOSIT) {
3290 setEventMessages($langs->trans(
"ErrorLinesCantBeNegativeOnDeposits"),
null,
'errors');
3292 setEventMessages($langs->trans(
"ErrorFieldCantBeNegativeOnInvoice", $langs->transnoentitiesnoconv(
"UnitPriceHT"), $langs->transnoentitiesnoconv(
"CustomerAbsoluteDiscountShort")),
null,
'errors');
3296 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"UnitPriceHT")),
null,
'errors');
3303 $previousprogress = $line->getAllPrevProgress($line->fk_facture);
3306 if ($fullprogress < $previousprogress) {
3308 setEventMessages($langs->trans(
'CantBeLessThanMinPercent'),
null,
'errors');
3312 if ($fullprogress > 100) {
3313 $fullprogress = 100;
3315 $addprogress = $fullprogress - $previousprogress;
3322 if (empty($usercancreatemargin)) {
3323 foreach (
$object->lines as &$line) {
3325 $fournprice = $line->fk_fournprice;
3326 $buyingprice = $line->pa_ht;
3332 $result =
$object->updateline(
3337 (
float) $remise_percent,
3355 (
float) $pu_ht_devise
3362 $outputlangs = $langs;
3365 $newlang =
GETPOST(
'lang_id',
'aZ09');
3368 $newlang =
$object->thirdparty->default_lang;
3370 if (!empty($newlang)) {
3372 $outputlangs->setDefaultLang($newlang);
3373 $outputlangs->load(
'products');
3375 $object->generateDocument(
$object->model_pdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
3378 unset($_POST[
'qty']);
3379 unset($_POST[
'type']);
3380 unset($_POST[
'productid']);
3381 unset($_POST[
'remise_percent']);
3382 unset($_POST[
'price_ht']);
3383 unset($_POST[
'multicurrency_price_ht']);
3384 unset($_POST[
'price_ttc']);
3385 unset($_POST[
'tva_tx']);
3386 unset($_POST[
'product_ref']);
3387 unset($_POST[
'product_label']);
3388 unset($_POST[
'product_desc']);
3389 unset($_POST[
'fournprice']);
3390 unset($_POST[
'buying_price']);
3391 unset($_POST[
'np_marginRate']);
3392 unset($_POST[
'np_markRate']);
3393 unset($_POST[
'dp_desc']);
3394 unset($_POST[
'idprod']);
3395 unset($_POST[
'units']);
3396 unset($_POST[
'date_starthour']);
3397 unset($_POST[
'date_startmin']);
3398 unset($_POST[
'date_startsec']);
3399 unset($_POST[
'date_startday']);
3400 unset($_POST[
'date_startmonth']);
3401 unset($_POST[
'date_startyear']);
3402 unset($_POST[
'date_endhour']);
3403 unset($_POST[
'date_endmin']);
3404 unset($_POST[
'date_endsec']);
3405 unset($_POST[
'date_endday']);
3406 unset($_POST[
'date_endmonth']);
3407 unset($_POST[
'date_endyear']);
3408 unset($_POST[
'situations']);
3409 unset($_POST[
'progress']);
3414 } elseif ($action ==
'updatealllines' && $usercancreate &&
GETPOST(
'all_percent') == $langs->trans(
'Modify')) {
3415 if (!
$object->fetch($id) > 0) {
3418 if (
GETPOST(
'all_progress') !=
"") {
3420 if ($all_progress > 100) {
3421 $all_progress = 100;
3424 foreach (
$object->lines as $line) {
3426 $percent = $line->getAllPrevProgress(
$object->id);
3428 $percent = $line->get_prev_progress(
$object->id);
3430 if (
$object->type != $object::TYPE_CREDIT_NOTE && (
float) $all_progress < (
float) $percent) {
3431 $mesg = $langs->trans(
"Line").
' '.$line->rang.
' : '.$langs->trans(
"CantBeLessThanMinPercent");
3434 } elseif (
$object->type == $object::TYPE_CREDIT_NOTE && (
float) $all_progress > (
float) $percent) {
3435 $mesg = $langs->trans(
"Line").
' '.$line->rang.
' : '.$langs->trans(
"CantBeMoreThanMinPercent");
3439 $object->update_percent($line, $all_progress,
false);
3444 } elseif ($action ==
'updateline' && $usercancreate && !$cancel) {
3445 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?facid='.$id);
3447 } elseif ($action ==
'confirm_situationout' && $confirm ==
'yes' && $usercancreate) {
3449 $object->fetch($id,
'',
'', 0,
true);
3452 &&
$object->isSituationInvoice()
3455 &&
$object->is_last_in_cycle()
3456 && $usercanunvalidate
3459 $newCycle =
$object->newCycle();
3460 if ($newCycle > 1) {
3462 $lastCycle =
$object->situation_cycle_ref;
3463 $lastSituationCounter =
$object->situation_counter;
3464 $linkedCreditNotesList = array();
3466 if (count(
$object->tab_next_situation_invoice) > 0) {
3467 foreach (
$object->tab_next_situation_invoice as $next_invoice) {
3469 && $next_invoice->situation_counter ==
$object->situation_counter
3470 && $next_invoice->fk_facture_source ==
$object->id
3472 $linkedCreditNotesList[] = $next_invoice->id;
3477 $object->situation_cycle_ref = $newCycle;
3478 $object->situation_counter = 1;
3480 if (
$object->update($user) > 0) {
3482 if (count($linkedCreditNotesList) > 0) {
3484 $sql =
'UPDATE '.MAIN_DB_PREFIX.
'facture';
3485 $sql .=
' SET situation_cycle_ref = '.((int) $newCycle);
3486 $sql .=
' , situation_final=0';
3487 $sql .=
' , situation_counter='.((int)
$object->situation_counter);
3488 $sql .=
' WHERE rowid IN ('.$db->sanitize(implode(
',', $linkedCreditNotesList)).
')';
3490 $resql =
$db->query($sql);
3496 foreach (
$object->lines as $line) {
3498 if ($line->product_type == 9) {
3503 if (!empty(
$object->tab_previous_situation_invoice)) {
3505 $lineIndex = count(
$object->tab_previous_situation_invoice) - 1;
3506 $searchPreviousInvoice =
true;
3507 while ($searchPreviousInvoice) {
3508 if (
$object->tab_previous_situation_invoice[$lineIndex]->isSituationInvoice() || $lineIndex < 1) {
3509 $searchPreviousInvoice =
false;
3517 $maxPrevSituationPercent = 0;
3518 foreach (
$object->tab_previous_situation_invoice[$lineIndex]->lines as $prevLine) {
3519 if ($prevLine->id == $line->fk_prev_id) {
3520 $maxPrevSituationPercent = max($maxPrevSituationPercent, $prevLine->situation_percent);
3525 $line->situation_percent -= $maxPrevSituationPercent;
3527 if ($line->update() < 0) {
3536 header(
"Location: ".$_SERVER[
'PHP_SELF'].
"?id=".$id);
3538 setEventMessages($langs->trans(
'ErrorOutingSituationInvoiceCreditNote'), array(),
'errors');
3541 setEventMessages($langs->trans(
'ErrorOutingSituationInvoiceOnUpdate'), array(),
'errors');
3544 setEventMessages($langs->trans(
'ErrorFindNextSituationInvoice'), array(),
'errors');
3550 $fromElement =
GETPOST(
'fromelement');
3551 $fromElementid =
GETPOST(
'fromelementid');
3552 $importLines =
GETPOST(
'line_checkbox');
3554 if (!empty($importLines) && is_array($importLines) && !empty($fromElement) && ctype_alpha($fromElement) && !empty($fromElementid)) {
3555 $lineClassName =
'';
3556 if ($fromElement ==
'commande') {
3558 $lineClassName =
'OrderLine';
3559 } elseif ($fromElement ==
'propal') {
3560 dol_include_once(
'/comm/'.$fromElement.
'/class/'.$fromElement.
'.class.php');
3561 $lineClassName =
'PropaleLigne';
3563 $nextRang = count(
$object->lines) + 1;
3566 foreach ($importLines as $lineId) {
3567 if ($lineClassName ===
'') {
3571 dol_syslog(
'compta/facture/card - No lineClassName - skip import', LOG_ERR);
3578 $lineId = intval($lineId);
3579 $originLine =
new $lineClassName(
$db);
3580 if (intval($fromElementid) > 0 && $originLine->fetch($lineId) > 0) {
3581 $originLine->fetch_optionals();
3582 $desc = $originLine->desc;
3583 $pu_ht = $originLine->subprice;
3584 $qty = $originLine->qty;
3585 $txtva = $originLine->tva_tx;
3586 $txlocaltax1 = $originLine->localtax1_tx;
3587 $txlocaltax2 = $originLine->localtax2_tx;
3588 $fk_product = $originLine->fk_product;
3589 $remise_percent = $originLine->remise_percent;
3591 $date_end = $originLine->date_end;
3592 $fk_code_ventilation = 0;
3593 $info_bits = $originLine->info_bits;
3594 $fk_remise_except = $originLine->fk_remise_except;
3595 $price_base_type =
'HT';
3597 $type = $originLine->product_type;
3598 $rang = $nextRang++;
3599 $special_code = $originLine->special_code;
3600 $origin = $originLine->element;
3601 $origin_id = $originLine->id;
3602 $fk_parent_line = 0;
3603 $fk_fournprice = $originLine->fk_fournprice;
3604 $pa_ht = $originLine->pa_ht;
3605 $label = $originLine->label;
3606 $array_options = $originLine->array_options;
3607 if (
$object->isSituationInvoice()) {
3608 $situation_percent = 0;
3610 $situation_percent = 100;
3613 $fk_unit = $originLine->fk_unit;
3614 $pu_ht_devise = $originLine->multicurrency_subprice;
3616 $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);
3636 include DOL_DOCUMENT_ROOT.
'/core/actions_printing.inc.php';
3642 if (!empty(
$object->id) && $action ==
'send') {
3644 $object->getSommePaiement(-1);
3645 $object->getSumCreditNotesUsed(-1);
3646 $object->getSumDepositsUsed(-1);
3648 $triggersendname =
'BILL_SENTBYMAIL';
3650 $autocopy =
'MAIN_MAIL_AUTOCOPY_INVOICE_TO';
3651 $trackid =
'inv'.$object->id;
3652 include DOL_DOCUMENT_ROOT.
'/core/actions_sendmails.inc.php';
3656 $permissiontoadd = $usercancreate;
3657 include DOL_DOCUMENT_ROOT.
'/core/actions_builddoc.inc.php';
3660 if ($action ==
'update_extras' && $permissiontoeditextra) {
3663 $attribute_name =
GETPOST(
'attribute',
'aZ09');
3666 $ret = $extrafields->setOptionalsFromPost(
null, $object, $attribute_name);
3673 $result =
$object->updateExtraField($attribute_name,
'BILL_MODIFY');
3681 $action =
'edit_extras';
3686 if ($action ==
'addcontact' && $usercancreate) {
3687 $result =
$object->fetch($id);
3689 if ($result > 0 && $id > 0) {
3692 $result =
$object->add_contact($contactid, $typeid,
GETPOST(
"source",
'aZ09'));
3696 header(
"Location: ".$_SERVER[
'PHP_SELF'].
"?id=".
$object->id);
3699 if (
$object->error ==
'DB_ERROR_RECORD_ALREADY_EXISTS') {
3700 $langs->load(
"errors");
3701 setEventMessages($langs->trans(
"ErrorThisContactIsAlreadyDefinedAsThisType"),
null,
'errors');
3706 } elseif ($action ==
'swapstatut' && $usercancreate) {
3713 } elseif ($action ==
'deletecontact' && $usercancreate) {
3716 $result =
$object->delete_contact($lineid);
3719 header(
"Location: ".$_SERVER[
'PHP_SELF'].
"?id=".
$object->id);
3727 $action =
'edit_extras';
3751$title =
$object->ref.
" - ".$langs->trans(
'Card');
3752if ($action ==
'create') {
3753 $title = $langs->trans(
"NewBill");
3755$help_url =
"EN:Customers_Invoices|FR:Factures_Clients|ES:Facturas_a_clientes";
3761if ($action ==
'create') {
3763 $extrafields->fetch_name_optionals_label($facturestatic->table_element);
3768 $res = $soc->fetch($socid);
3771 $currency_code =
$conf->currency;
3773 $cond_reglement_id =
GETPOSTINT(
'cond_reglement_id');
3774 $mode_reglement_id =
GETPOSTINT(
'mode_reglement_id');
3778 if (empty($dateinvoice)) {
3784 if (!empty($origin) && !empty($originid)) {
3786 $element = $subelement = $origin;
3788 if (preg_match(
'/^([^_]+)_([^_]+)/i', $origin, $regs)) {
3789 $element = $regs[1];
3790 $subelement = $regs[2];
3795 if ($element ==
'project') {
3796 $projectid = $originid;
3798 if (empty($cond_reglement_id)) {
3799 $cond_reglement_id = $soc->cond_reglement_id;
3801 if (empty($mode_reglement_id)) {
3802 $mode_reglement_id = $soc->mode_reglement_id;
3804 if (empty($fk_account)) {
3805 $fk_account = $soc->fk_account;
3809 if ($element ==
'order' || $element ==
'commande') {
3810 $element = $subelement =
'commande';
3812 if ($element ==
'propal') {
3813 $element =
'comm/propal';
3814 $subelement =
'propal';
3816 if ($element ==
'contract') {
3817 $element = $subelement =
'contrat';
3819 if ($element ==
'shipping') {
3820 $element = $subelement =
'expedition';
3825 $classname = ucfirst($subelement);
3826 $objectsrc =
new $classname(
$db);
3827 '@phan-var-force Commande|Propal|Contrat|Expedition|Facture $objectsrc';
3829 $objectsrc->fetch($originid);
3830 if (empty($objectsrc->lines) && method_exists($objectsrc,
'fetch_lines')) {
3831 $objectsrc->fetch_lines();
3833 $objectsrc->fetch_thirdparty();
3835 $projectid = (!empty($projectid) ? $projectid : $objectsrc->fk_project);
3841 $ref_client = (!empty($objectsrc->ref_client) ? $objectsrc->ref_client : (!empty($objectsrc->ref_customer) ? $objectsrc->ref_customer :
''));
3845 if (empty($socid)) {
3846 $soc = $objectsrc->thirdparty;
3849 if ($element ==
'expedition') {
3850 $elem = $subelem = $objectsrc->origin_type;
3851 $expeoriginid = $objectsrc->origin_id;
3853 $classname = ucfirst($subelem);
3855 $expesrc =
new $classname(
$db);
3856 '@phan-var-force Expedition $expesrc';
3858 dol_syslog(
"Is type Facture|Commande or Expedition: $element...expesrc($classname)=".get_class($expesrc));
3859 $expesrc->fetch($expeoriginid);
3861 $cond_reglement_id = (!empty($expesrc->cond_reglement_id) ? $expesrc->cond_reglement_id : (!empty($soc->cond_reglement_id) ? $soc->cond_reglement_id : 1));
3862 $mode_reglement_id = (!empty($expesrc->mode_reglement_id) ? $expesrc->mode_reglement_id : (!empty($soc->mode_reglement_id) ? $soc->mode_reglement_id : 0));
3863 $fk_account = (!empty($expesrc->fk_account) ? $expesrc->fk_account : (!empty($soc->fk_account) ? $soc->fk_account : 0));
3866 $currency_code = (!empty($expesrc->multicurrency_code) ? $expesrc->multicurrency_code : (!empty($soc->multicurrency_code) ? $soc->multicurrency_code : $objectsrc->multicurrency_code));
3867 $currency_tx = (!empty($expesrc->multicurrency_tx) ? $expesrc->multicurrency_tx : (!empty($soc->multicurrency_tx) ? $soc->multicurrency_tx : $objectsrc->multicurrency_tx));
3871 $inputReasonId = (!empty($objectsrc->demand_reason_id) ? $objectsrc->demand_reason_id : (!empty($soc->demand_reason_id) ? $soc->demand_reason_id : 0));
3874 $expesrc->fetch_optionals();
3875 $object->array_options = $expesrc->array_options;
3877 $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)));
3878 $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)));
3879 $fk_account = (!empty($objectsrc->fk_account) ? $objectsrc->fk_account : (!empty($soc->fk_account) ? $soc->fk_account : (!empty($fk_account) ? $fk_account : 0)));
3882 if (!empty($objectsrc->multicurrency_code)) {
3883 $currency_code = $objectsrc->multicurrency_code;
3885 if (
getDolGlobalString(
'MULTICURRENCY_USE_ORIGIN_TX') && !empty($objectsrc->multicurrency_tx)) {
3886 $currency_tx = $objectsrc->multicurrency_tx;
3891 $inputReasonId = (!empty($objectsrc->demand_reason_id) ? $objectsrc->demand_reason_id : (!empty($soc->demand_reason_id) ? $soc->demand_reason_id : 0));
3894 $objectsrc->fetch_optionals();
3895 $object->array_options = $objectsrc->array_options;
3899 $cond_reglement_id = empty($soc->cond_reglement_id) ? $cond_reglement_id : $soc->cond_reglement_id;
3900 $mode_reglement_id = empty($soc->mode_reglement_id) ? $mode_reglement_id : $soc->mode_reglement_id;
3901 $fk_account = empty($soc->fk_account) ? $fk_account : $soc->fk_account;
3902 $inputReasonId = empty($soc->demand_reason_id) ? $inputReasonId : $soc->demand_reason_id;
3904 if (
isModEnabled(
'multicurrency') && !empty($soc->multicurrency_code)) {
3905 $currency_code = $soc->multicurrency_code;
3910 if (!
GETPOST(
'changecompany')) {
3911 if (GETPOSTISSET(
'cond_reglement_id')) {
3912 $cond_reglement_id =
GETPOSTINT(
'cond_reglement_id');
3914 if (GETPOSTISSET(
'mode_reglement_id')) {
3915 $mode_reglement_id =
GETPOSTINT(
'mode_reglement_id');
3917 if (GETPOSTISSET(
'cond_reglement_id')) {
3923 if (empty($cond_reglement_id)) {
3924 $cond_reglement_id =
GETPOSTINT(
"cond_reglement_id");
3928 if (empty($mode_reglement_id)) {
3929 $mode_reglement_id =
GETPOSTINT(
"mode_reglement_id");
3939 if (!empty($soc->id)) {
3940 $absolute_discount = $soc->getAvailableDiscounts();
3942 $note_public =
$object->getDefaultCreateValueFor(
'note_public', ((!empty($origin) && !empty($originid) && is_object($objectsrc) &&
getDolGlobalString(
'FACTURE_REUSE_NOTES_ON_CREATE_FROM')) ? $objectsrc->note_public : null));
3943 $note_private =
$object->getDefaultCreateValueFor(
'note_private', ((!empty($origin) && !empty($originid) && is_object($objectsrc) &&
getDolGlobalString(
'FACTURE_REUSE_NOTES_ON_CREATE_FROM')) ? $objectsrc->note_private : null));
3945 if (!empty(
$conf->use_javascript_ajax)) {
3946 require_once DOL_DOCUMENT_ROOT.
'/core/lib/ajax.lib.php';
3952 if ($origin ==
'contrat') {
3953 $langs->load(
"admin");
3954 $text = $langs->trans(
"ToCreateARecurringInvoice");
3955 $text .=
' '.$langs->trans(
"ToCreateARecurringInvoiceGene", $langs->transnoentitiesnoconv(
"MenuFinancial"), $langs->transnoentitiesnoconv(
"BillsCustomers"), $langs->transnoentitiesnoconv(
"ListOfTemplates"));
3957 $text .=
' '.$langs->trans(
"ToCreateARecurringInvoiceGeneAuto", $langs->transnoentitiesnoconv(
'Module2300Name'));
3959 print
info_admin($text, 0, 0,
'info',
'').
'<br>';
3962 print
'<form name="add" action="'.$_SERVER[
"PHP_SELF"].
'" method="POST" id="formtocreate" name="formtocreate">';
3963 print
'<input type="hidden" name="token" value="'.newToken().
'">';
3964 print
'<input type="hidden" name="action" id="formtocreateaction" value="add">';
3965 print
'<input type="hidden" name="changecompany" value="0">';
3967 print
'<input type="hidden" name="socid" value="'.$soc->id.
'">'.
"\n";
3969 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
3970 print
'<input name="ref" type="hidden" value="provisoire">';
3971 print
'<input name="ref_client" type="hidden" value="'.$ref_client.
'">';
3972 print
'<input name="force_cond_reglement_id" type="hidden" value="0">';
3973 print
'<input name="force_mode_reglement_id" type="hidden" value="0">';
3974 print
'<input name="force_fk_account" type="hidden" value="0">';
3975 print
'<input type="hidden" name="origin" value="'.$origin.
'">';
3976 print
'<input type="hidden" name="originid" value="'.$originid.
'">';
3977 print
'<input type="hidden" name="originentity" value="'.GETPOSTINT(
'originentity').
'">';
3978 if (!empty($currency_tx)) {
3979 print
'<input type="hidden" name="originmulticurrency_tx" value="'.$currency_tx.
'">';
3985 $parameters = array();
3987 $reshook = $hookmanager->executeHooks(
'tabContentCreateInvoice', $parameters, $object, $action);
3988 if (empty($reshook)) {
3989 print
'<table class="border centpercent">';
3993 if (empty($origin) && empty($originid) &&
GETPOSTINT(
'fac_rec') > 0) {
3994 $invoice_predefined->fetch(
GETPOSTINT(
'fac_rec'));
4007 if ($soc->id > 0 && (!
GETPOSTINT(
'fac_rec') || !empty($invoice_predefined->frequency))) {
4009 print
'<tr><td class="fieldrequired titlefieldcreate">'.$langs->trans(
'Customer').
'</td>';
4010 print
'<td colspan="2">';
4011 print $soc->getNomUrl(1,
'customer');
4012 print
'<input type="hidden" name="socid" value="'.$soc->id.
'">';
4014 $arrayoutstandingbills = $soc->getOutstandingBills();
4015 $outstandingBills = $arrayoutstandingbills[
'opened'];
4016 print
' - <span class="opacitymedium valignmiddle">'.$langs->trans(
'CurrentOutstandingBill').
':</span> ';
4017 print
'<span class="amount valignmiddle">'.price($outstandingBills, 0, $langs, 0, 0, -1,
$conf->currency).
'</span>';
4018 if ($soc->outstanding_limit !=
'') {
4019 if ($outstandingBills > $soc->outstanding_limit) {
4020 print
img_warning($langs->trans(
"OutstandingBillReached"));
4022 print
' / '.price($soc->outstanding_limit, 0, $langs, 0, 0, -1,
$conf->currency);
4027 print
'<tr><td class="fieldrequired">'.$langs->trans(
'Customer').
'</td>';
4028 print
'<td colspan="2">';
4029 $filter =
'((s.client:IN:1,2,3) AND (s.status:=:1))';
4030 print
img_picto(
'',
'company',
'class="pictofixedwidth"').$form->select_company($soc->id,
'socid', $filter,
'SelectThirdParty', 1, 0, array(), 0,
'minwidth300 widthcentpercentminusxx maxwidth500');
4034 $(document).ready(function() {
4035 $("#socid").change(function() {
4037 console.log("Submit page");
4038 $(\'input[name="action"]\').val(\'create\');
4039 $(\'input[name="force_cond_reglement_id"]\').val(\'1\');
4040 $(\'input[name="force_mode_reglement_id"]\').val(\'1\');
4041 $(\'input[name="force_fk_account"]\').val(\'1\');
4042 $("#formtocreate").submit(); */
4044 // For company change, we must submit page with action=create instead of action=add
4045 console.log("We have changed the company - Resubmit page");
4046 jQuery("input[name=changecompany]").val("1");
4047 jQuery("#formtocreateaction").val("create");
4048 jQuery("#formtocreate").submit();
4054 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>';
4061 if (empty($origin) && empty($originid) &&
GETPOSTINT(
'fac_rec') > 0) {
4063 foreach ($invoice_predefined->array_options as $key => $option) {
4064 if (!isset(
$object->array_options[$key])) {
4065 $object->array_options[$key] = $invoice_predefined->array_options[$key];
4069 $dateinvoice = $invoice_predefined->date_when;
4070 if (empty($projectid)) {
4071 $projectid = $invoice_predefined->fk_project;
4073 $cond_reglement_id = $invoice_predefined->cond_reglement_id;
4074 $mode_reglement_id = $invoice_predefined->mode_reglement_id;
4075 $fk_account = $invoice_predefined->fk_account;
4076 $note_public = $invoice_predefined->note_public;
4077 $note_private = $invoice_predefined->note_private;
4079 if (!empty($invoice_predefined->multicurrency_code)) {
4080 $currency_code = $invoice_predefined->multicurrency_code;
4082 if (!empty($invoice_predefined->multicurrency_tx)) {
4083 $currency_tx = $invoice_predefined->multicurrency_tx;
4086 $sql =
'SELECT r.rowid, r.titre as title, r.total_ttc';
4087 $sql .=
' FROM '.MAIN_DB_PREFIX.
'facture_rec as r';
4088 $sql .=
' WHERE r.fk_soc = '.((int) $invoice_predefined->socid);
4090 $resql =
$db->query($sql);
4092 $num =
$db->num_rows($resql);
4096 print
'<tr><td>'.$langs->trans(
'CreateFromRepeatableInvoice').
'</td><td>';
4098 print
'<select class="flat" id="fac_rec" name="fac_rec">';
4099 print
'<option value="0" selected></option>';
4101 $objp =
$db->fetch_object($resql);
4102 print
'<option value="'.$objp->rowid.
'"';
4105 $exampletemplateinvoice->fetch(
GETPOSTINT(
'fac_rec'));
4107 print
'>'.$objp->title.
' ('.
price($objp->total_ttc).
' '.$langs->trans(
"TTC").
')</option>';
4116 print
'<script type="text/javascript">
4117 $(document).ready(function() {
4118 $("#fac_rec").change(function() {
4119 console.log("We have changed the template invoice - Reload page");
4120 var fac_rec = $(this).val();
4121 var socid = $(\'#socid\').val();
4122 // 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.
4123 window.location.href = "'.$_SERVER[
"PHP_SELF"].
'?action=create&socid="+socid+"&fac_rec="+fac_rec;
4136 print
'<tr><td class="tdtop fieldrequired titlefieldcreate">'.$langs->trans(
'Type').
'</td><td colspan="2">';
4137 print
'<div class="listofinvoicetypetable">'.
"\n";
4140 print
'<div class="listofinvoicetype"><div class="">';
4141 $tmp =
'<input type="radio" id="radio_standard" name="type" value="0"'.(GETPOSTINT(
'type') ?
'' :
' checked').
'> ';
4142 $tmp .=
'<label for="radio_standard" >'.$langs->trans(
"InvoiceStandardAsk");
4143 $tmp .=
' <span class="opacitymedium">'.$langs->trans(
"InvoiceStandardAsk2").
'</span>';
4146 $desc = $form->textwithpicto($tmp, $langs->transnoentities(
"InvoiceStandardDesc").
'<br><br>'.$langs->transnoentities(
"YouMustCreateStandardInvoiceFirstDesc"), 1,
'help',
'nowraponall', 0, 3,
'standardonsmartphone');
4148 if ((($origin ==
'propal') || ($origin ==
'commande')) && (!empty($originid))) {
4158 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%') .
'"/>';
4161 print
'</div></div>'.
"\n";
4163 if ((empty($origin)) || ((($origin ==
'propal') || ($origin ==
'commande')) && (!empty($originid)))) {
4166 print
'<div class="listofinvoicetype"><div class="">';
4167 $tmp =
'<input type="radio" id="radio_deposit" name="type" value="3"'.(GETPOSTINT(
'type') == 3 ?
' checked' :
'').
'> ';
4168 print
'<script type="text/javascript">
4169 jQuery(document).ready(function() {
4170 jQuery("#typestandardinvoice, #valuestandardinvoice").click(function() {
4171 jQuery("#radio_standard").prop("checked", true);
4173 jQuery("#typedeposit, #valuedeposit").click(function() {
4174 jQuery("#radio_deposit").prop("checked", true);
4176 jQuery("#typedeposit").change(function() {
4177 console.log("We change type of down payment: "+jQuery("#typedeposit").val());
4179 if (jQuery("#typedeposit").val() == "amount") {
4180 jQuery("#valuedeposit").attr("placeholder", "'.$langs->getCurrencySymbol(
$conf->currency).
'");
4181 jQuery("#valuedeposit").val("");
4183 jQuery("#valuedeposit").attr("placeholder", "50%");
4184 jQuery("#valuedeposit").val("");
4187 jQuery("#radio_deposit").prop("checked", true);
4188 setRadioForTypeOfInvoice();
4190 jQuery("#radio_standard, #radio_deposit, #radio_replacement, #radio_creditnote, #radio_template").change(function() {
4191 setRadioForTypeOfInvoice();
4194 function setRadioForTypeOfInvoice() {
4195 console.log("Change radio for type of invoice");
4196 if (jQuery("#radio_deposit").prop("checked") && (jQuery("#typedeposit").val() == \'amount\' || jQuery("#typedeposit").val() == \'variable\')) {
4197 jQuery("#checkforselects").prop("disabled", true);
4198 jQuery("#checkforselects").prop("checked", false);
4199 jQuery(".checkforselect").prop("disabled", true);
4200 jQuery(".checkforselect").prop("checked", false);
4202 jQuery("#checkforselects").prop("disabled", false);
4203 jQuery("#checkforselects").prop("checked", true);
4204 jQuery(".checkforselect").prop("disabled", false);
4205 jQuery(".checkforselect").prop("checked", true);
4211 $tmp = $tmp.
'<label for="radio_deposit">'.$langs->trans(
"InvoiceDeposit").
'</label>';
4213 $desc = $form->textwithpicto($tmp, $langs->transnoentities(
"InvoiceDepositDesc"), 1,
'help',
'', 0, 3,
'depositonsmartphone');
4215 if (($origin ==
'propal') || ($origin ==
'commande')) {
4218 'amount' => $langs->transnoentitiesnoconv(
'FixAmount', $langs->transnoentitiesnoconv(
'Deposit')),
4219 'variable' => $langs->transnoentitiesnoconv(
'VarAmountOneLine', $langs->transnoentitiesnoconv(
'Deposit')),
4220 'variablealllines' => $langs->transnoentitiesnoconv(
'VarAmountAllLines')
4224 'variablealllines' => $langs->transnoentitiesnoconv(
'VarAmountAllLines')
4228 $typedeposit =
GETPOST(
'typedeposit',
'aZ09');
4230 if (empty($typedeposit) && !empty($objectsrc->deposit_percent)) {
4231 $origin_payment_conditions_deposit_percent = getDictionaryValue(
'c_payment_term',
'deposit_percent', $objectsrc->cond_reglement_id);
4232 if (!empty($origin_payment_conditions_deposit_percent)) {
4233 $typedeposit =
'variable';
4236 if (empty($valuedeposit) && $typedeposit ==
'variable' && !empty($objectsrc->deposit_percent)) {
4237 $valuedeposit = $objectsrc->deposit_percent;
4239 print
'<span class="marginleftonly">'.$form->selectarray(
'typedeposit', $arraylist, $typedeposit, 0, 0, 0,
'', 1).
'</span>';
4241 print
'<input type="text" id="valuedeposit" name="valuedeposit" class="width75 right" value="'.($valuedeposit ? $valuedeposit :
'').
'"'.($valuedeposit ?
'' :
'placeholder="'.$langs->getCurrencySymbol(
$conf->currency).
'"').
'>';
4244 print
'</div></div>'.
"\n";
4251 print
'<div class="listofinvoicetype"><div class="">';
4252 $tmp =
'<input id="radio_situation" type="radio" name="type" value="5"'.(GETPOST(
'type') == 5 ?
' checked' :
'').
'> ';
4253 $tmp = $tmp.
'<label for="radio_situation" >'.$langs->trans(
"InvoiceFirstSituationAsk").
'</label>';
4255 $desc = $form->textwithpicto($tmp, $langs->transnoentities(
"InvoiceFirstSituationDesc"), 1,
'help',
'', 0, 3,
'firstsituationonsmartphone');
4259 $opt = $form->selectSituationInvoices((
string)
GETPOSTINT(
'originid'), $socid);
4262 print
'</div></div><div class="listofinvoicetype"><div>';
4264 $tmp =
'<input id="radio_situation_bis" type="radio" name="type" value="5"'.(GETPOST(
'type') == 5 &&
GETPOSTINT(
'originid') ?
' checked' :
'');
4265 if ($opt == (
'<option value="0" selected>'.$langs->trans(
'NoSituations').
'</option>') || (
GETPOST(
'origin') &&
GETPOST(
'origin') !=
'facture' &&
GETPOST(
'origin') !=
'commande')) {
4266 $tmp .=
' disabled';
4269 $text = $tmp.
'<label for="radio_situation_bis">'.$langs->trans(
"InvoiceSituationAsk").
'</label> ';
4271 $text .=
'<select class="flat minwidth125" id="situations" name="situations"';
4272 if ($opt == (
'<option value="0" selected>'.$langs->trans(
'NoSituations').
'</option>') || (
GETPOST(
'origin') &&
GETPOST(
'origin') !=
'facture' &&
GETPOST(
'origin') !=
'commande')) {
4273 $text .=
' disabled';
4277 $text .=
'</select>';
4278 $desc = $form->textwithpicto($text, $langs->transnoentities(
"InvoiceSituationDesc"), 1,
'help',
'', 0, 3);
4280 print
'</div></div>'.
"\n";
4286 $facids = $facturestatic->list_replacable_invoices($soc->id);
4292 if (is_array($facids)) {
4293 foreach ($facids as $facparam) {
4294 $options .=
'<option value="'.$facparam [
'id'].
'"';
4295 if ($facparam[
'id'] ==
GETPOSTINT(
'fac_replacement')) {
4296 $options .=
' selected';
4298 $options .=
'>'.$facparam[
'ref'];
4299 $options .=
' ('.$facturestatic->LibStatut($facparam[
'paid'], $facparam[
'status'], 0, $facparam[
'alreadypaid']).
')';
4300 $options .=
'</option>';
4304 print
'<!-- replacement line -->';
4305 print
'<div class="listofinvoicetype"><div class="">';
4306 $tmp =
'<input type="radio" name="type" id="radio_replacement" value="1"'.(GETPOST(
'type') == 1 ?
' checked' :
'');
4307 if (!$options || $invoice_predefined->id > 0) {
4308 $tmp .=
' disabled';
4311 print
'<script type="text/javascript">
4312 jQuery(document).ready(function() {
4313 jQuery("#fac_replacement").change(function() {
4314 console.log("We change fac_replacement");
4315 jQuery("#radio_replacement").prop("checked", true);
4319 $text = $tmp.
'<label for="radio_replacement">'.$langs->trans(
"InvoiceReplacementAsk").
'</label>';
4320 $text .=
'<select class="flat" name="fac_replacement" id="fac_replacement"';
4321 if (!$options || $invoice_predefined->id > 0) {
4322 $text .=
' disabled';
4326 $text .=
'<option value="-1"> </option>';
4329 $text .=
'<option value="-1">'.$langs->trans(
"NoReplacableInvoice").
'</option>';
4331 $text .=
'</select>';
4332 $desc = $form->textwithpicto($text, $langs->transnoentities(
"InvoiceReplacementDesc"), 1,
'help',
'', 0, 3);
4334 print
'</div></div>'.
"\n";
4338 print
'<div class="listofinvoicetype"><div class="">';
4339 $tmp =
'<input type="radio" name="type" id="radio_situation" value="0" disabled> ';
4340 $text = $tmp.
'<label class="opacitymedium">'.$langs->trans(
"InvoiceSituationAsk").
'</label> ';
4341 $desc = $form->textwithpicto($text, $langs->transnoentities(
"InvoiceFirstSituationDesc").
'<br><br>'.$langs->trans(
"YouMustCreateInvoiceFromThird"), 1,
'help',
'nowraponall', 0, 3,
'firstsituationonsmartphone');
4343 print
'</div></div>'.
"\n";
4346 print
'<div class="listofinvoicetype"><div class="">';
4347 $tmp =
'<input type="radio" name="type" id="radio_replacement" value="0" disabled> ';
4348 $text = $tmp.
'<label for="radio_replacement" class="opacitymedium">'.$langs->trans(
"InvoiceReplacement").
'</label> ';
4349 $desc = $form->textwithpicto($text, $langs->transnoentities(
"InvoiceReplacementDesc").
'<br><br>'.$langs->trans(
"YouMustCreateInvoiceFromThird"), 1,
'help',
'nowraponall', 0, 3,
'replacementonsmartphone');
4351 print
'</div></div>'.
"\n";
4354 if (empty($origin)) {
4359 $facids = $facturestatic->list_qualified_avoir_invoices($soc->id);
4366 foreach ($facids as $key => $valarray) {
4367 $newinvoice_static->id = $key;
4368 $newinvoice_static->ref = $valarray [
'ref'];
4369 $newinvoice_static->statut = $valarray [
'status'];
4370 $newinvoice_static->status = $valarray [
'status'];
4371 $newinvoice_static->type = $valarray [
'type'];
4372 $newinvoice_static->paye = $valarray [
'paye'];
4373 $newinvoice_static->paid = $valarray [
'paye'];
4375 $optionsav .=
'<option value="'.$key.
'"';
4376 if ($key ==
GETPOST(
'fac_avoir')) {
4377 $optionsav .=
' selected';
4380 $newinvoice_static->fetch_optionals($key);
4381 $object->array_options = $newinvoice_static->array_options;
4384 $optionsav .= $newinvoice_static->ref;
4385 $optionsav .=
' ('.$newinvoice_static->getLibStatut(1, $valarray [
'paymentornot']).
')';
4386 $optionsav .=
'</option>';
4389 print
'<div class="listofinvoicetype"><div class="">';
4390 $tmp =
'<input type="radio" id="radio_creditnote" name="type" value="2"'.(GETPOST(
'type') == 2 ?
' checked' :
'');
4391 if ((!$optionsav && !
getDolGlobalString(
'INVOICE_CREDIT_NOTE_STANDALONE')) || $invoice_predefined->id > 0) {
4392 $tmp .=
' disabled';
4396 print
'<script type="text/javascript">
4397 jQuery(document).ready(function() {
4398 if (jQuery("#radio_creditnote").is(":checked")) {
4399 jQuery("#radio_standard").prop("disabled", true);
4400 jQuery("#radio_deposit").prop("disabled", true);
4402 jQuery("#radio_standard").prop("disabled", false);
4403 jQuery("#radio_deposit").prop("disabled", false);
4405 if (! jQuery("#radio_creditnote").is(":checked")) {
4406 jQuery("#credit_note_options").hide();
4408 jQuery("#radio_creditnote").click(function() {
4409 jQuery("#credit_note_options").show();
4411 jQuery("#radio_standard, #radio_replacement, #radio_deposit, #radio_situation, #radio_situation_bis").click(function() {
4412 console.log("We click on a radio to close credit not options");
4413 jQuery("#credit_note_options").hide();
4417 $text =
'<label>'.$tmp.$langs->transnoentities(
"InvoiceAvoirAsk").
'</label> ';
4418 $text .=
'<select class="flat valignmiddle minwidth200" name="fac_avoir" id="fac_avoir"';
4419 if (!$optionsav || $invoice_predefined->id > 0) {
4420 $text .=
' disabled';
4424 $text .=
'<option value="-1">'.$langs->trans(
"InvoiceAvoirAskCombo").
'</option>';
4425 $text .= $optionsav;
4427 $text .=
'<option value="-1">'.$langs->trans(
"NoInvoiceToCorrect").
'</option>';
4429 $text .=
'</select>';
4430 $desc = $form->textwithpicto($text, $langs->transnoentities(
"InvoiceAvoirDesc"), 1,
'help',
'', 0, 3);
4433 print
'<div id="credit_note_options" class="clearboth paddingtop marginbottomonly">';
4434 print
'<div class="marginleftlargeondesktop"><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>";
4435 print
'<div class="marginleftlargeondesktop"><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>";
4440 print
'</div></div>'.
"\n";
4443 print
'<div class="listofinvoicetype"><div class="">';
4445 $tmp =
'<input type="radio" name="type" id="radio_creditnote" value="0" disabled> ';
4447 $tmp =
'<input type="radio" name="type" id="radio_creditnote" value="2" > ';
4449 $text = $tmp.
'<label class="opacitymedium" for="radio_creditnote">'.$langs->trans(
"InvoiceAvoir").
'</label> ';
4451 $desc = $form->textwithpicto($text, $langs->transnoentities(
"InvoiceAvoirDesc").
'<br><br>'.$langs->trans(
"CreateCreditNoteWhenClientInvoiceExists"), 1,
'help',
'', 0, 3,
'creditnoteonsmartphone');
4453 print
'</div></div>'.
"\n";
4474 foreach ($listtType as $type) {
4475 $thisTypeConfName =
'FACTURE_ADDON_PDF_'.$type;
4477 $jsListType .= (!empty($jsListType) ?
',' :
'').
'"'.$type.
'":"'.$current.
'"';
4480 print
'<script type="text/javascript">
4481 $(document).ready(function() {
4482 var listType = {'.$jsListType.
'};
4483 $("[name=\'type\'").change(function() {
4484 console.log("change name=type");
4485 if ($( this ).prop("checked"))
4487 if(($( this ).val() in listType))
4489 $("#model").val(listType[$( this ).val()]);
4506 print
'<tr><td class="fieldrequired">'.$langs->trans(
'InvoiceSubtype').
'</td><td colspan="2">';
4507 print $form->getSelectInvoiceSubtype(
GETPOSTINT(
'subtype'),
'subtype', 1, 0,
'');
4513 print
'<tr><td>'.$langs->trans(
'DiscountStillRemaining').
'</td><td colspan="2">';
4517 $backtopage = $_SERVER[
"PHP_SELF"].
'?socid='.$thirdparty->id.
'&action='.$action.
'&origin='.urlencode((
string) (
GETPOST(
'origin'))).
'&originid='.urlencode((
string) (
GETPOSTINT(
'originid')));
4520 $defaulttpldir =
'/core/tpl';
4521 $dirtpls = array_merge(
$conf->modules_parts[
'tpl'], array($defaulttpldir));
4522 foreach ($dirtpls as $module => $reldir) {
4524 if (!empty($module)) {
4527 $tpl = DOL_DOCUMENT_ROOT.$reldir.
'/object_discounts.tpl.php';
4529 if (file_exists($tpl)) {
4530 if (empty(
$conf->file->strict_mode)) {
4531 $res = @include $tpl;
4533 $res = include $tpl;
4548 print
'<tr><td class="fieldrequired">'.$langs->trans(
'DateInvoice').
'</td><td colspan="2">';
4549 print
img_picto(
'',
'action',
'class="pictofixedwidth"');
4550 print $form->selectDate($newdateinvoice ? $newdateinvoice : $dateinvoice,
'', 0, 0, 0,
"add", 1, 1);
4555 print
'<tr><td class="fieldrequired">'.$langs->trans(
'DatePointOfTax').
'</td><td colspan="2">';
4556 print
img_picto(
'',
'action',
'class="pictofixedwidth"');
4557 print $form->selectDate($date_pointoftax ? $date_pointoftax : -1,
'date_pointoftax', 0, 0, 0,
"add", 1, 1);
4562 print
'<tr><td class="nowrap fieldrequired">'.$langs->trans(
'PaymentConditionsShort').
'</td><td colspan="2">';
4563 print
img_picto(
'',
'payment',
'class="pictofixedwidth"');
4564 print $form->getSelectConditionsPaiements((
int) $cond_reglement_id,
'cond_reglement_id', -1, 1, 0,
'maxwidth500 widthcentpercentminusx');
4569 $rwStyle =
'display:none;';
4570 if (in_array(
GETPOSTINT(
'type'), $retainedWarrantyInvoiceAvailableType)) {
4574 $retained_warranty =
GETPOSTINT(
'retained_warranty');
4575 if (empty($retained_warranty)) {
4576 if ($objectsrc !==
null && property_exists($objectsrc,
'retained_warranty') && !empty($objectsrc->retained_warranty)) {
4578 $retained_warranty = $objectsrc->retained_warranty;
4581 $retained_warranty_js_default = !empty($retained_warranty) ? $retained_warranty :
getDolGlobalString(
'INVOICE_SITUATION_DEFAULT_RETAINED_WARRANTY_PERCENT');
4583 print
'<tr class="retained-warranty-line" style="'.$rwStyle.
'" ><td class="nowrap">'.$langs->trans(
'RetainedWarranty').
'</td><td colspan="2">';
4584 print
'<input id="new-situation-invoice-retained-warranty" name="retained_warranty" type="number" value="'.$retained_warranty.
'" step="0.01" min="0" max="100" />%';
4587 print
'<tr class="retained-warranty-line" style="'.$rwStyle.
'" ><td class="nowrap">'.$langs->trans(
'PaymentConditionsShortRetainedWarranty').
'</td><td colspan="2">';
4588 $retained_warranty_fk_cond_reglement =
GETPOSTINT(
'retained_warranty_fk_cond_reglement');
4589 if (empty($retained_warranty_fk_cond_reglement)) {
4590 $retained_warranty_fk_cond_reglement =
getDolGlobalString(
'INVOICE_SITUATION_DEFAULT_RETAINED_WARRANTY_COND_ID');
4591 if ($objectsrc instanceOf
Facture && !empty($objectsrc->retained_warranty_fk_cond_reglement)) {
4593 $retained_warranty_fk_cond_reglement = $objectsrc->retained_warranty_fk_cond_reglement;
4596 print $form->getSelectConditionsPaiements($retained_warranty_fk_cond_reglement,
'retained_warranty_fk_cond_reglement', -1, 1);
4599 print
'<script type="text/javascript">
4600 $(document).ready(function() {
4601 $("[name=\'type\']").change(function() {
4602 if($( this ).prop("checked") && $.inArray($( this ).val(), '.json_encode($retainedWarrantyInvoiceAvailableType).
' ) !== -1)
4604 $(".retained-warranty-line").show();
4605 $("#new-situation-invoice-retained-warranty").val("'.(float) $retained_warranty_js_default.
'");
4608 $(".retained-warranty-line").hide();
4609 $("#new-situation-invoice-retained-warranty").val("");
4613 $("[name=\'type\']:checked").trigger("change");
4619 print
'<tr><td>'.$langs->trans(
'PaymentMode').
'</td><td colspan="2">';
4620 print
img_picto(
'',
'bank',
'class="pictofixedwidth"');
4621 print $form->select_types_paiements((
string) $mode_reglement_id,
'mode_reglement_id',
'CRDT', 0, 1, 0, 0, 1,
'maxwidth250 widthcentpercentminusx', 1);
4626 print
'<tr><td>'.$langs->trans(
'DefaultBankAccount').
'</td><td colspan="2">';
4627 print
img_picto(
'',
'bank_account',
'class="pictofixedwidth"');
4628 print $form->select_comptes((
int) $fk_account,
'fk_account', 0,
'', 1,
'', 0,
'maxwidth250 widthcentpercentminusx', 1);
4634 print
'<tr><td>'.$langs->trans(
'Source').
'</td><td>';
4635 print
img_picto(
'',
'question',
'class="pictofixedwidth"');
4636 $form->selectInputReason((
string) $inputReasonId,
'input_reason_id',
'', 1,
'maxwidth250 widthcentpercentminusx');
4639 print
'<input type="hidden" name="input_reason_id" value="'.((string) $inputReasonId).
'">';
4643 if (
isModEnabled(
'project') && is_object($formproject)) {
4644 $langs->load(
'projects');
4645 print
'<tr><td>'.$langs->trans(
'Project').
'</td><td colspan="2">';
4646 print
img_picto(
'',
'project',
'class="pictofixedwidth"');
4648 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');
4649 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>';
4656 print
'<td><label for="incoterm_id">'.$form->textwithpicto($langs->trans(
"IncotermLabel"), !empty($objectsrc->label_incoterms) ? $objectsrc->label_incoterms :
'', 1).
'</label></td>';
4657 print
'<td colspan="2" class="maxwidthonsmartphone">';
4658 $incoterm_id =
GETPOST(
'incoterm_id');
4659 $location_incoterms =
GETPOST(
'location_incoterms');
4660 if (empty($incoterm_id)) {
4661 $incoterm_id = (!empty($objectsrc->fk_incoterms) ? $objectsrc->fk_incoterms : $soc->fk_incoterms);
4662 $location_incoterms = (!empty($objectsrc->location_incoterms) ? $objectsrc->location_incoterms : $soc->location_incoterms);
4664 print
img_picto(
'',
'incoterm',
'class="pictofixedwidth"');
4665 print $form->select_incoterms($incoterm_id, $location_incoterms);
4679 print
'<tr><td>'.$langs->trans(
"Categories").
'</td><td colspan="3">';
4680 print $form->selectCategories(Categorie::TYPE_INVOICE,
'categories', $object);
4685 $parameters = array(
'objectsrc' => !empty($objectsrc) ? $objectsrc : 0,
'colspan' =>
' colspan="2"',
'cols' =>
'2',
'socid' => $socid);
4686 $reshook = $hookmanager->executeHooks(
'formObjectOptions', $parameters, $object, $action);
4687 print $hookmanager->resPrint;
4688 if (empty($reshook)) {
4689 if (
getDolGlobalString(
'THIRDPARTY_PROPAGATE_EXTRAFIELDS_TO_INVOICE') && !empty($soc->id)) {
4692 $tpExtrafieldLabels = $tpExtrafields->fetch_name_optionals_label($soc->table_element);
4693 if ($soc->fetch_optionals() > 0) {
4694 $object->array_options = array_merge(
$object->array_options, $soc->array_options);
4698 print
$object->showOptionals($extrafields,
'create', $parameters);
4702 include_once DOL_DOCUMENT_ROOT.
'/core/modules/facture/modules_facture.php';
4704 if (is_array($list) && count($list) > 0) {
4708 $paramkey =
'FACTURE_ADDON_PDF_'.$type;
4713 if (count($list) > 1) {
4714 print
'<tr><td>'.$langs->trans(
'Model').
'</td>';
4715 print
'<td colspan="2">';
4716 print
img_picto(
'',
'pdf',
'class="pictofixedwidth"');
4717 print $form->selectarray(
'model', $list, $preselected, 0, 0, 0,
'', 0, 0, 0,
'',
'maxwidth200 widthcentpercentminusx', 1);
4720 print
'<input type="hidden" name="model" value="'.$preselected.
'">';
4727 print
'<td>'.$form->editfieldkey(
'Currency',
'multicurrency_code',
'', $object, 0).
'</td>';
4728 print
'<td colspan="2" class="maxwidthonsmartphone">';
4729 print
img_picto(
'',
'currency',
'class="pictofixedwidth"');
4730 print $form->selectMultiCurrency(((GETPOSTISSET(
'multicurrency_code') && !
GETPOST(
'changecompany')) ?
GETPOST(
'multicurrency_code') : $currency_code),
'multicurrency_code', 0,
'', false,
'maxwidth200 widthcentpercentminusx');
4737 $dateexample = ($newdateinvoice ? $newdateinvoice : $dateinvoice);
4738 if (empty($dateexample)) {
4741 $substitutionarray = array(
4742 '__TOTAL_HT__' => $langs->trans(
"AmountHT").
' ('.$langs->trans(
"Example").
': '.
price($exampletemplateinvoice->total_ht).
')',
4743 '__TOTAL_TTC__' => $langs->trans(
"AmountTTC").
' ('.$langs->trans(
"Example").
': '.
price($exampletemplateinvoice->total_ttc).
')',
4744 '__INVOICE_PREVIOUS_MONTH__' => $langs->trans(
"PreviousMonthOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date(
dol_time_plus_duree($dateexample, -1,
'm'),
'%m').
')',
4745 '__INVOICE_MONTH__' => $langs->trans(
"MonthOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date($dateexample,
'%m').
')',
4746 '__INVOICE_NEXT_MONTH__' => $langs->trans(
"NextMonthOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date(
dol_time_plus_duree($dateexample, 1,
'm'),
'%m').
')',
4747 '__INVOICE_PREVIOUS_MONTH_TEXT__' => $langs->trans(
"TextPreviousMonthOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date(
dol_time_plus_duree($dateexample, -1,
'm'),
'%B').
')',
4748 '__INVOICE_MONTH_TEXT__' => $langs->trans(
"TextMonthOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date($dateexample,
'%B').
')',
4749 '__INVOICE_NEXT_MONTH_TEXT__' => $langs->trans(
"TextNextMonthOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date(
dol_time_plus_duree($dateexample, 1,
'm'),
'%B').
')',
4750 '__INVOICE_PREVIOUS_YEAR__' => $langs->trans(
"PreviousYearOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date(
dol_time_plus_duree($dateexample, -1,
'y'),
'%Y').
')',
4751 '__INVOICE_YEAR__' => $langs->trans(
"YearOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date($dateexample,
'%Y').
')',
4752 '__INVOICE_NEXT_YEAR__' => $langs->trans(
"NextYearOfInvoice").
' ('.$langs->trans(
"Example").
': '.
dol_print_date(
dol_time_plus_duree($dateexample, 1,
'y'),
'%Y').
')'
4755 $htmltext =
'<i>'.$langs->trans(
"FollowingConstantsWillBeSubstituted").
':<br>';
4756 foreach ($substitutionarray as $key => $val) {
4757 $htmltext .= $key.
' = '.$langs->trans($val).
'<br>';
4759 $htmltext .=
'</i>';
4764 print
'<td class="tdtop">';
4765 print $form->textwithpicto($langs->trans(
'NotePublic'), $htmltext);
4767 print
'<td valign="top" colspan="2">';
4768 $doleditor =
new DolEditor(
'note_public', (
string) $note_public,
'', 80,
'dolibarr_notes',
'In',
false,
false, !
getDolGlobalString(
'FCKEDITOR_ENABLE_NOTE_PUBLIC') ? 0 : 1, ROWS_3,
'90%');
4769 print $doleditor->Create(1);
4772 if (empty($user->socid)) {
4774 print
'<td class="tdtop">';
4775 print $form->textwithpicto($langs->trans(
'NotePrivate'), $htmltext);
4777 print
'<td valign="top" colspan="2">';
4778 $doleditor =
new DolEditor(
'note_private', (
string) $note_private,
'', 80,
'dolibarr_notes',
'In',
false,
false, !
getDolGlobalString(
'FCKEDITOR_ENABLE_NOTE_PRIVATE') ? 0 : 1, ROWS_3,
'90%');
4779 print $doleditor->Create(1);
4785 if (!empty($origin) && !empty($originid) && is_object($objectsrc) && !empty($classname)) {
4786 $langs->loadLangs(array(
'orders',
'propal'));
4789 if ($origin ==
'contrat') {
4790 '@phan-var-force Contrat $objectsrc';
4792 $objectsrc->update_price(1,
'auto', 1);
4795 print
"\n<!-- Show ref of origin ".$classname.
" -->\n";
4796 print
'<input type="hidden" name="amount" value="'.$objectsrc->total_ht.
'">'.
"\n";
4797 print
'<input type="hidden" name="total" value="'.$objectsrc->total_ttc.
'">'.
"\n";
4798 print
'<input type="hidden" name="tva" value="'.$objectsrc->total_tva.
'">'.
"\n";
4803 switch (get_class($objectsrc)) {
4805 $newclassname =
'CommercialProposal';
4808 $newclassname =
'Order';
4811 $newclassname =
'Sending';
4814 $newclassname =
'Contract';
4817 $newclassname =
'Intervention';
4820 $newclassname = get_class($objectsrc);
4824 print
'<tr><td>'.$langs->trans($newclassname).
'</td>';
4825 print
'<td colspan="2">';
4826 print $objectsrc->getNomUrl(1);
4828 $objectsrc->fetchObjectLinked($originid, $origin,
null,
'facture');
4829 if (isset($objectsrc->linkedObjects[
'facture']) && is_array($objectsrc->linkedObjects[
'facture']) && count($objectsrc->linkedObjects[
'facture']) >= 1) {
4831 echo
' - '.$langs->trans(
'LatestRelatedBill').
' '.end($objectsrc->linkedObjects[
'facture'])->getNomUrl(1);
4835 print
'<tr><td>'.$langs->trans(
'AmountHT').
'</td><td colspan="2">'.
price($objectsrc->total_ht, 1, $langs, 1, -1,
'',
$conf->currency).
'</td></tr>';
4836 print
'<tr><td>'.$langs->trans(
'AmountVAT').
'</td><td colspan="2">'.
price($objectsrc->total_tva, 1, $langs, 1, -1,
'',
$conf->currency).
"</td></tr>";
4837 if (
$mysoc->localtax1_assuj ==
"1" || $objectsrc->total_localtax1 != 0) {
4838 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>";
4841 if (
$mysoc->localtax2_assuj ==
"1" || $objectsrc->total_localtax2 != 0) {
4842 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>";
4844 print
'<tr><td>'.$langs->trans(
'AmountTTC').
'</td><td colspan="2">'.
price($objectsrc->total_ttc, 1, $langs, 1, -1,
'',
$conf->currency).
"</td></tr>";
4846 if (
isModEnabled(
'multicurrency') && $objectsrc->multicurrency_code !=
$conf->currency) {
4848 print
'<tr><td>'.$langs->trans(
'MulticurrencyAmountHT').
'</td><td colspan="2">'.
price($objectsrc->multicurrency_total_ht, 1, $langs, 1, -1,
'', $objectsrc->multicurrency_code).
'</td></tr>';
4849 print
'<tr><td>'.$langs->trans(
'MulticurrencyAmountVAT').
'</td><td colspan="2">'.
price($objectsrc->multicurrency_total_tva, 1, $langs, 1, -1,
'', $objectsrc->multicurrency_code).
"</td></tr>";
4850 print
'<tr><td>'.$langs->trans(
'MulticurrencyAmountTTC').
'</td><td colspan="2">'.
price($objectsrc->multicurrency_total_ttc, 1, $langs, 1, -1,
'', $objectsrc->multicurrency_code).
"</td></tr>";
4858 print $form->buttonsSaveCancel(
"CreateDraft");
4861 if (!empty($origin) && !empty($originid) && is_object($objectsrc)) {
4864 $title = $langs->trans(
'ProductsAndServices');
4867 print
'<div class="div-table-responsive-no-min">';
4868 print
'<table class="noborder centpercent">';
4870 $objectsrc->printOriginLinesList(
'', $selectedLines);
4877} elseif ($id > 0 || !empty($ref)) {
4879 $langs->load(
'errors');
4880 echo
'<div class="error">'.$langs->trans(
"ErrorRecordNotFound").
'</div>';
4889 if ($user->socid > 0 && $user->socid !=
$object->socid) {
4893 $result =
$object->fetch_thirdparty();
4895 $result = $soc->fetch(
$object->socid);
4899 $selleruserevenustamp =
$mysoc->useRevenueStamp();
4901 $totalpaid =
$object->getSommePaiement();
4902 $totalcreditnotes =
$object->getSumCreditNotesUsed();
4903 $totaldeposits =
$object->getSumDepositsUsed();
4909 $resteapayer =
price2num(
$object->total_ttc - $totalpaid - $totalcreditnotes - $totaldeposits,
'MT');
4913 $multicurrency_totalpaid =
$object->getSommePaiement(1);
4914 $multicurrency_totalcreditnotes =
$object->getSumCreditNotesUsed(1);
4915 $multicurrency_totaldeposits =
$object->getSumDepositsUsed(1);
4916 $multicurrency_resteapayer =
price2num(
$object->multicurrency_total_ttc - $multicurrency_totalpaid - $multicurrency_totalcreditnotes - $multicurrency_totaldeposits,
'MT');
4920 if ($resteapayer == 0 && $multicurrency_resteapayer != 0 &&
$object->multicurrency_code !=
$conf->currency) {
4921 $resteapayer =
price2num((
float) $multicurrency_resteapayer /
$object->multicurrency_tx,
'MT');
4925 if (
$object->paye ||
$object->status == $object::STATUS_CLOSED) {
4928 $resteapayeraffiche = $resteapayer;
4931 $filterabsolutediscount =
"fk_facture_source IS NULL";
4932 $filtercreditnote =
"fk_facture_source IS NOT NULL";
4934 $filterabsolutediscount =
"fk_facture_source IS NULL OR (description LIKE '(DEPOSIT)%' AND description NOT LIKE '(EXCESS RECEIVED)%')";
4935 $filtercreditnote =
"fk_facture_source IS NOT NULL AND (description NOT LIKE '(DEPOSIT)%' OR description LIKE '(EXCESS RECEIVED)%')";
4938 $absolute_discount = $soc->getAvailableDiscounts(
null, $filterabsolutediscount);
4939 $absolute_creditnote = $soc->getAvailableDiscounts(
null, $filtercreditnote);
4940 $absolute_discount =
price2num($absolute_discount,
'MT');
4941 $absolute_creditnote =
price2num($absolute_creditnote,
'MT');
4943 $nb_creditnote_notyetavailable = $soc->getOpenCreditNotesNotYetConvertedIntoDiscount(0);
4946 if (
$object->user_creation_id) {
4947 $author->fetch(
$object->user_creation_id);
4950 $objectidnext =
$object->getIdReplacingInvoice();
4954 print
dol_get_fiche_head($head,
'compta', $langs->trans(
'InvoiceCustomer'), -1,
$object->picto, 0,
'',
'', 0,
'', 1);
4959 if ($action ==
'converttoreduc') {
4961 $type_fac =
'ExcessReceived';
4963 $type_fac =
'CreditNote';
4965 $type_fac =
'Deposit';
4969 $text = $langs->trans(
'ConfirmConvertToReduc', strtolower($langs->transnoentities($type_fac)));
4970 $text .=
'<br>'.$langs->trans(
'ConfirmConvertToReduc2');
4971 $formconfirm = $form->formconfirm($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, $langs->trans(
'ConvertToReduc'), $text,
'confirm_converttoreduc',
'',
"yes", 2);
4975 if ($action ==
'delete') {
4976 $text = $langs->trans(
'ConfirmDeleteBill',
$object->ref);
4977 $formquestion = array();
4980 $qualified_for_stock_change = 0;
4982 $qualified_for_stock_change =
$object->hasProductsOrServices(2);
4984 $qualified_for_stock_change =
$object->hasProductsOrServices(1);
4987 if ($qualified_for_stock_change) {
4988 $langs->load(
"stocks");
4989 require_once DOL_DOCUMENT_ROOT.
'/product/class/html.formproduct.class.php';
4993 if (
$conf->browser->name ==
'ie') {
4996 $formquestion = array(
5000 array(
'type' =>
'other',
'name' =>
'idwarehouse',
'label' => $label,
'value' => $formproduct->selectWarehouses(
GETPOST(
'idwarehouse') ?
GETPOST(
'idwarehouse') :
'ifone',
'idwarehouse',
'', 1, 0, 0, $langs->trans(
"NoStockAction"), 0, $forcecombo))
5002 $formconfirm = $form->formconfirm($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, $langs->trans(
'DeleteBill'), $text,
'confirm_delete', $formquestion,
"yes", 1);
5004 $formconfirm = $form->formconfirm($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, $langs->trans(
'DeleteBill'), $text,
'confirm_delete',
'',
'no', 1);
5007 $formconfirm = $form->formconfirm($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, $langs->trans(
'DeleteBill'), $text,
'confirm_delete',
'',
'no', 1);
5012 if ($action ==
'situationout') {
5013 $text = $langs->trans(
'ConfirmRemoveSituationFromCycle',
$object->ref);
5014 $label = $langs->trans(
"ConfirmOuting");
5015 $formquestion = array();
5020 &&
$object->is_last_in_cycle()
5021 && $usercanunvalidate
5023 $formconfirm = $form->formconfirm($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, $label, $text,
'confirm_situationout', $formquestion,
"yes", 1);
5028 if ($action ==
'valid') {
5030 $objectref = substr(
$object->ref, 1, 4);
5031 if ($objectref ==
'PROV') {
5035 $object->date_lim_reglement =
$object->calculate_date_lim_reglement();
5037 $numref =
$object->getNextNumRef($soc);
5043 $text = $langs->trans(
'ConfirmValidateBill', $numref);
5045 $text .=
'<br><br>';
5046 $text .=
img_picto(
'',
'warning',
'class="pictofixedwidth"').
' '.$langs->trans(
'WarningInvoiceCanNeverBeEdited');
5049 require_once DOL_DOCUMENT_ROOT.
'/core/class/notify.class.php';
5052 $text .= $notify->confirmMessage(
'BILL_VALIDATE',
$object->socid, $object);
5054 $formquestion = array();
5057 $qualified_for_stock_change = 0;
5059 $qualified_for_stock_change =
$object->hasProductsOrServices(2);
5061 $qualified_for_stock_change =
$object->hasProductsOrServices(1);
5064 if ($qualified_for_stock_change) {
5065 $langs->load(
"stocks");
5066 require_once DOL_DOCUMENT_ROOT.
'/product/class/html.formproduct.class.php';
5067 require_once DOL_DOCUMENT_ROOT.
'/product/stock/class/entrepot.class.php';
5070 $warehouse_array = $warehouse->list_array();
5071 if (count($warehouse_array) == 1) {
5072 $label =
$object->type ==
Facture::TYPE_CREDIT_NOTE ? $langs->trans(
"WarehouseForStockIncrease", current($warehouse_array)) : $langs->trans(
"WarehouseForStockDecrease", current($warehouse_array));
5073 $value =
'<input type="hidden" id="idwarehouse" name="idwarehouse" value="'.key($warehouse_array).
'">';
5076 $value = $formproduct->selectWarehouses(
GETPOST(
'idwarehouse') ?
GETPOST(
'idwarehouse') :
'ifone',
'idwarehouse',
'', 1);
5078 $formquestion = array(
5084 array(
'type' =>
'other',
'name' =>
'idwarehouse',
'label' => $label,
'value' => $value));
5088 $text .=
'<br>'.img_warning().
' '.$langs->trans(
"ErrorInvoiceOfThisTypeMustBePositive");
5093 foreach (
$object->lines as $line) {
5094 $res = $line->fetch_product();
5096 if ($line->product->isService() && $line->product->isMandatoryPeriod() && (empty($line->date_start) || empty($line->date_end))) {
5102 if ($nbMandated > 0) {
5104 setEventMessages($langs->trans(
"mandatoryPeriodNeedTobeSetMsgValidate"),
null,
'errors');
5107 $text .=
'<div><span class="clearboth nowraponall warning">'.img_warning().$langs->trans(
"mandatoryPeriodNeedTobeSetMsgValidate").
'</span></div>';
5112 $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);
5117 if ($action ==
'modif') {
5120 $testvalue =
$object->isEditable();
5121 if ($testvalue < 0) {
5122 switch ($testvalue) {
5125 setEventMessages($langs->trans(
"DisabledBecauseDispatchedInBookkeeping"),
null,
'errors');
5129 setEventMessages($langs->trans(
"DisabledBecauseNotLastInvoice"),
null,
'errors');
5133 setEventMessages($langs->trans(
"DisabledBecauseNotLastSituationInvoice"),
null,
'errors');
5137 setEventMessages($langs->trans(
"DisabledBecauseThereIsAPayment"),
null,
'errors');
5141 setEventMessages($langs->trans(
"DisabledBecauseAlreadySentByEmail"),
null,
'errors');
5145 setEventMessages($langs->trans(
"DisabledBecauseAlreadyPrintedOnce"),
null,
'errors');
5161 $text = $langs->trans(
'ConfirmUnvalidateBill',
$object->ref);
5162 $formquestion = array();
5165 $qualified_for_stock_change = 0;
5167 $qualified_for_stock_change =
$object->hasProductsOrServices(2);
5169 $qualified_for_stock_change =
$object->hasProductsOrServices(1);
5172 if ($qualified_for_stock_change) {
5173 $langs->load(
"stocks");
5174 require_once DOL_DOCUMENT_ROOT.
'/product/class/html.formproduct.class.php';
5175 require_once DOL_DOCUMENT_ROOT.
'/product/stock/class/entrepot.class.php';
5178 $warehouse_array = $warehouse->list_array();
5179 if (count($warehouse_array) == 1) {
5180 $label =
$object->type ==
Facture::TYPE_CREDIT_NOTE ? $langs->trans(
"WarehouseForStockDecrease", current($warehouse_array)) : $langs->trans(
"WarehouseForStockIncrease", current($warehouse_array));
5181 $value =
'<input type="hidden" id="idwarehouse" name="idwarehouse" value="'.key($warehouse_array).
'">';
5184 $value = $formproduct->selectWarehouses(
GETPOST(
'idwarehouse') ?
GETPOST(
'idwarehouse') :
'ifone',
'idwarehouse',
'', 1);
5186 $formquestion = array(
5192 array(
'type' =>
'other',
'name' =>
'idwarehouse',
'label' => $label,
'value' => $value));
5196 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?facid='.
$object->id, $langs->trans(
'UnvalidateBill'), $text,
'confirm_modif', $formquestion,
"yes", 1);
5201 if ($action ==
'canceled') {
5205 $statusreplacement = 0;
5207 if ($objectidnext) {
5209 $facturereplacement->fetch($objectidnext);
5210 $statusreplacement = $facturereplacement->status;
5212 if ($objectidnext && $statusreplacement == 0) {
5213 print
'<div class="error">'.$langs->trans(
"ErrorCantCancelIfReplacementInvoiceNotValidated").
'</div>';
5217 $close[1][
'code'] =
'badcustomer';
5218 $close[2][
'code'] =
'abandon';
5220 $close[1][
'label'] = $langs->trans(
"ConfirmClassifyPaidPartiallyReasonBadCustomerDesc");
5221 $close[2][
'label'] = $langs->trans(
"ConfirmClassifyAbandonReasonOtherDesc");
5223 $close[1][
'reason'] = $form->textwithpicto($langs->transnoentities(
"ConfirmClassifyPaidPartiallyReasonBadCustomer",
$object->ref), $close[1][
'label'], 1);
5224 $close[2][
'reason'] = $form->textwithpicto($langs->transnoentities(
"ConfirmClassifyAbandonReasonOther"), $close[2][
'label'], 1);
5227 $arrayreasons[$close[1][
'code']] = $close[1][
'reason'];
5228 $arrayreasons[$close[2][
'code']] = $close[2][
'reason'];
5231 $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'));
5233 $formconfirm = $form->formconfirm($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, $langs->trans(
'CancelBill'), $langs->trans(
'ConfirmCancelBill',
$object->ref),
'confirm_canceled', $formquestion,
"yes", 1, 300);
5238 if ($action ==
'paid' && ($resteapayer <= 0 || (
getDolGlobalString(
'INVOICE_CAN_SET_PAID_EVEN_IF_PARTIALLY_PAID') && $resteapayer ==
$object->total_ttc))) {
5239 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?facid='.
$object->id, $langs->trans(
'ClassifyPaid'), $langs->trans(
'ConfirmClassifyPaidBill',
$object->ref),
'confirm_paid',
'',
"yes", 1);
5241 if ($action ==
'paid' && $resteapayer > 0 && (!
getDolGlobalString(
'INVOICE_CAN_SET_PAID_EVEN_IF_PARTIALLY_PAID') || $resteapayer !=
$object->total_ttc)) {
5245 $close[$i][
'code'] = $object::CLOSECODE_DISCOUNTVAT;
5247 $close[$i][
'code'] = $object::CLOSECODE_BADDEBT;
5249 $close[$i][
'code'] = $object::CLOSECODE_BANKCHARGE;
5251 $close[$i][
'code'] = $object::CLOSECODE_WITHHOLDINGTAX;
5253 $close[$i][
'code'] = $object::CLOSECODE_OTHER;
5257 $close[$i][
'label'] = $langs->trans(
"HelpEscompte").
'<br><br>'.$langs->trans(
"ConfirmClassifyPaidPartiallyReasonDiscountVatDesc");
5259 $close[$i][
'label'] = $langs->trans(
"ConfirmClassifyPaidPartiallyReasonBadCustomerDesc");
5261 $close[$i][
'label'] = $langs->trans(
"ConfirmClassifyPaidPartiallyReasonBankChargeDesc");
5263 $close[$i][
'label'] = $langs->trans(
"ConfirmClassifyPaidPartiallyReasonWithholdingTaxDesc");
5265 $close[$i][
'label'] = $langs->trans(
"Other");
5269 $close[$i][
'reason'] = $form->textwithpicto($langs->transnoentities(
"ConfirmClassifyPaidPartiallyReasonDiscount", $resteapayer, $langs->trans(
"Currency".$conf->currency)), $close[$i][
'label'], 1);
5271 $close[$i][
'reason'] = $form->textwithpicto($langs->transnoentities(
"ConfirmClassifyPaidPartiallyReasonBadCustomer", $resteapayer, $langs->trans(
"Currency".$conf->currency)), $close[$i][
'label'], 1);
5273 $close[$i][
'reason'] = $form->textwithpicto($langs->transnoentities(
"ConfirmClassifyPaidPartiallyReasonBankCharge", $resteapayer, $langs->trans(
"Currency".$conf->currency)), $close[$i][
'label'], 1);
5275 $close[$i][
'reason'] = $form->textwithpicto($langs->transnoentities(
"ConfirmClassifyPaidPartiallyReasonWithholdingTax"), $close[$i][
'label'], 1);
5277 $close[$i][
'reason'] = $form->textwithpicto($langs->transnoentities(
"Other"), $close[$i][
'label'], 1);
5281 foreach ($close as $key => $val) {
5282 $arrayreasons[$close[$key][
'code']] =
'<span class="small">'.$close[$key][
'reason'].
'</span>';
5286 $formquestion = array(
5287 'text' => $langs->trans(
"ConfirmClassifyPaidPartiallyQuestion"),
5288 0 => array(
'type' =>
'radio',
'name' =>
'close_code',
'label' =>
'',
'values' => $arrayreasons),
5289 1 => array(
'type' =>
'text',
'name' =>
'close_note',
'moreattr' =>
'placeholder = "'.$langs->trans(
"Comment").
'"',
'value' =>
'',
'morecss' =>
'minwidth300'),
5290 2 => array(
'type' =>
'separator')
5293 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&resteapayer='.((
float) $resteapayer), $langs->trans(
'ClassifyPaid'), $langs->trans(
'ConfirmClassifyPaidPartially',
$object->ref),
'confirm_paid_partially', $formquestion,
"yes", 1, 420, 600);
5296 if ($action ==
'deletepayment') {
5297 $payment_id =
GETPOST(
'paiement_id');
5298 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'&paiement_id='.$payment_id, $langs->trans(
'DeletePayment'), $langs->trans(
'ConfirmDeletePayment'),
'confirm_delete_paiement',
'',
'no', 1);
5302 if ($action ==
'ask_deleteline') {
5303 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&lineid='.$lineid, $langs->trans(
'DeleteProductLine'), $langs->trans(
'ConfirmDeleteProductLine'),
'confirm_deleteline',
'',
'no', 1);
5307 if ($action ==
'ask_subtotal_deleteline') {
5308 $langs->load(
"subtotals");
5309 $title =
"DeleteSubtotalLine";
5310 $question =
"ConfirmDeleteSubtotalLine";
5311 if (
GETPOST(
'type') ==
'title') {
5312 $formconfirm = array(array(
'type' =>
'checkbox',
'name' =>
'deletecorrespondingsubtotalline',
'label' => $langs->trans(
"DeleteCorrespondingSubtotalLine"),
'value' => 0));
5313 $title =
"DeleteTitleLine";
5314 $question =
"ConfirmDeleteTitleLine";
5316 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&lineid='.$lineid, $langs->trans($title), $langs->trans($question),
'confirm_delete_subtotalline', $formconfirm,
'no', 1);
5320 if ($action ==
'clone') {
5321 $filter =
'(s.client:IN:1,2,3)';
5323 $formquestion = array(
5324 array(
'type' =>
'other',
'name' =>
'socid',
'label' => $langs->trans(
"SelectThirdParty"),
'value' => $form->select_company(
$object->socid,
'socid', $filter, 1)),
5325 array(
'type' =>
'date',
'name' =>
'newdate',
'label' => $langs->trans(
"Date"),
'value' =>
dol_now())
5328 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"].
'?facid='.
$object->id, $langs->trans(
'ToClone'), $langs->trans(
'ConfirmCloneInvoice',
$object->ref),
'confirm_clone', $formquestion,
'yes', 1, 250);
5332 if ($action ==
'add_title_line') {
5333 $langs->load(
'subtotals');
5335 $depth_array =
$object->getPossibleLevels($langs);
5337 } elseif ($action ==
'add_subtotal_line') {
5338 $langs->load(
'subtotals');
5340 $titles =
$object->getPossibleTitles();
5344 if ($action ==
"remove_file_comfirm") {
5345 $file =
GETPOST(
'file',
'alpha');
5347 $formconfirm = $form->formconfirm(
5348 $_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&file='.urlencode($file),
5349 $langs->trans(
'DeleteFileHeader'),
5350 $langs->trans(
'DeleteFileText').
"<br><br>".$file,
5359 $parameters = array(
'formConfirm' => $formconfirm,
'lineid' => $lineid,
'remainingtopay' => &$resteapayer);
5360 $reshook = $hookmanager->executeHooks(
'formConfirm', $parameters, $object, $action);
5361 if (empty($reshook)) {
5362 $formconfirm .= $hookmanager->resPrint;
5363 } elseif ($reshook > 0) {
5364 $formconfirm = $hookmanager->resPrint;
5372 $linkback =
'<a href="'.DOL_URL_ROOT.
'/compta/facture/list.php?restore_lastsearch_values=1'.(!empty($socid) ?
'&socid='.$socid :
'').
'">'.$langs->trans(
"BackToList").
'</a>';
5374 $morehtmlref =
'<div class="refidno">';
5377 $morehtmlref .= $form->editfieldkey(
"Ref",
'ref',
$object->ref, $object, (
int) $usercancreate,
'string',
'', 0, 1);
5378 $morehtmlref .= $form->editfieldval(
"Ref",
'ref',
$object->ref, $object, (
int) $usercancreate,
'string',
'',
null,
null,
'', 1);
5379 $morehtmlref .=
'<br>';
5382 $morehtmlref .= $form->editfieldkey(
"RefCustomer",
'ref_client',
$object->ref_customer, $object, (
int) $usercancreate,
'string',
'', 0, 1);
5383 $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);
5385 $morehtmlref .=
'<br>'.$object->thirdparty->getNomUrl(1,
'customer');
5387 $morehtmlref .=
' (<a href="'.DOL_URL_ROOT.
'/compta/facture/list.php?socid='.
$object->thirdparty->id.
'&search_societe='.urlencode(
$object->thirdparty->name).
'">'.$langs->trans(
"OtherBills").
'</a>)';
5391 $langs->load(
"projects");
5392 $morehtmlref .=
'<br>';
5393 if ($usercancreate) {
5394 $morehtmlref .=
img_picto($langs->trans(
"Project"),
'project',
'class="pictofixedwidth"');
5395 if ($action !=
'classify') {
5396 $morehtmlref .=
'<a class="editfielda" href="'.dolBuildUrl($_SERVER[
'PHP_SELF'], [
'action' =>
'classify',
'id' =>
$object->id],
true).
'">'.
img_edit($langs->transnoentitiesnoconv(
'SetProject')).
'</a> ';
5398 $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');
5400 if (!empty(
$object->fk_project)) {
5402 $proj->fetch(
$object->fk_project);
5403 $morehtmlref .= $proj->getNomUrl(1);
5405 $morehtmlref .=
'<span class="opacitymedium"> - '.dol_escape_htmltag($proj->title).
'</span>';
5410 $morehtmlref .=
'</div>';
5412 $object->totalpaid = $totalpaid;
5413 $object->totalcreditnotes = $totalcreditnotes;
5414 $object->totaldeposits = $totaldeposits;
5417 dol_banner_tab($object,
'ref', $linkback, 1,
'ref',
'ref', $morehtmlref,
'', 0,
'',
'');
5420 $parameters = array();
5422 $reshook = $hookmanager->executeHooks(
'tabContentViewInvoice', $parameters, $object, $action);
5423 if (empty($reshook)) {
5424 print
'<div class="fichecenter">';
5425 print
'<div class="fichehalfleft">';
5426 print
'<div class="underbanner clearboth"></div>';
5428 print
'<table class="border centpercent tableforfield">';
5431 print
'<tr><td class="fieldname_type">'.$langs->trans(
'Type').
'</td><td class="valuefield fieldname_type">';
5434 print
' '.$object->getSubtypeLabel(
'facture');
5438 $facreplaced->fetch(
$object->fk_facture_source);
5439 print
' <span class="opacitymediumbycolor paddingleft">'.$langs->transnoentities(
"ReplaceInvoice", $facreplaced->getNomUrl(1,
'', 32)).
'</span>';
5443 $facusing->fetch(
$object->fk_facture_source);
5444 print
' <span class="opacitymediumbycolor paddingleft">'.$langs->transnoentities(
"CorrectInvoice", $facusing->getNomUrl(1,
'', 32)).
'</span>';
5448 $object->getListIdAvoirFromInvoice();
5450 if (!empty(
$object->creditnote_ids)) {
5451 print
' <span class="opacitymediumbycolor paddingleft">'.$langs->transnoentities(
"InvoiceHasAvoir");
5453 foreach (
$object->creditnote_ids as $invoiceid) {
5460 $creditnote->fetch($invoiceid);
5461 print $creditnote->getNomUrl(1,
'', 32);
5465 if ($objectidnext > 0) {
5467 $facthatreplace->fetch($objectidnext);
5468 print
' <span class="opacitymediumbycolor paddingleft">'.str_replace(
'{s1}', $facthatreplace->getNomUrl(1), $langs->transnoentities(
"ReplacedByInvoice",
'{s1}')).
'</span>';
5473 $result = $discount->fetch(0,
$object->id);
5475 print
' <span class="opacitymediumbycolor paddingleft">';
5476 $s = $langs->trans(
"CreditNoteConvertedIntoDiscount",
'{s1}',
'{s2}');
5477 $s = str_replace(
'{s1}',
$object->getLibType(0), $s);
5478 $s = str_replace(
'{s2}', $discount->getNomUrl(1,
'discount'), $s);
5480 print
'</span><br>';
5484 if (
$object->fk_fac_rec_source > 0) {
5486 $result = $tmptemplate->fetch(
$object->fk_fac_rec_source);
5488 print
' <span class="opacitymediumbycolor paddingleft">';
5489 $s = $langs->transnoentities(
"GeneratedFromTemplate",
'{s1}');
5490 $s = str_replace(
'{s1}', $tmptemplate->getNomUrl(1,
'', 32), $s);
5494 print
' <span class="opacitymediumbycolor paddingleft">';
5495 print $langs->transnoentities(
"GeneratedFromTemplate", $langs->trans(
"ObjectDeleted"));
5503 $langs->load(
"cashdesk");
5504 print
'<tr><td class="fieldname_type">';
5505 print
'<table class="nobordernopadding centpercent"><tr><td>';
5506 print $form->textwithpicto($langs->trans(
'PointOfSale'), $langs->trans(
'POSInfo'));
5508 if ($action !=
'editposinfo' && $usercancreate) {
5509 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>';
5511 print
'</tr></table>';
5512 print
'</td><td class="valuefield fieldname_type">';
5513 print
'<form method="POST" action="'.$_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'" name="formposinfo">';
5514 print
'<input type="hidden" name="action" value="setposinfo">';
5515 print
'<input type="hidden" name="token" value="' . newToken() .
'">';
5516 if ($action ==
'editposinfo') {
5517 print
'<input type="text" class="maxwidth150" name="posmodule" placeholder="'.$langs->trans(
"POSModule").
'" value="'.
$object->module_source.
'"> ';
5518 print
'<input type="text" class="maxwidth100" name="posterminal" placeholder="'.$langs->trans(
"Terminal").
'" value="'.
$object->pos_source.
'">';
5519 print
'<input type="submit" class="button" name="submitposinfo" value="'.$langs->trans(
"Submit").
'">';
5522 print
'<span class="opacitymediumbycolor paddingleft">'.dolPrintHTML(ucfirst(
$object->module_source).
' - '.$langs->transnoentitiesnoconv(
"Terminal").
' '.
$object->pos_source).
'</span>';
5530 print
'<!-- Discounts -->'.
"\n";
5531 print
'<tr><td>'.$langs->trans(
'DiscountStillRemaining').
'</td>';
5535 $backtopage = $_SERVER[
"PHP_SELF"].
'?facid='.
$object->id;
5536 $defaulttpldir =
'/core/tpl';
5538 $dirtpls = array_merge(
$conf->modules_parts[
'tpl'], array($defaulttpldir));
5539 foreach ($dirtpls as $module => $reldir) {
5541 if (!empty($module)) {
5544 $tpl = DOL_DOCUMENT_ROOT.$reldir.
'/object_discounts.tpl.php';
5546 if (file_exists($tpl)) {
5547 if (empty(
$conf->file->strict_mode)) {
5548 $res = @include $tpl;
5550 $res = include $tpl;
5562 print
'<table class="nobordernopadding centpercent"><tr><td>';
5563 print $langs->trans(
'DateInvoice');
5565 if ($action !=
'editinvoicedate' &&
$object->status == $object::STATUS_DRAFT && $usercancreate && !
getDolGlobalString(
'FAC_FORCE_DATE_VALIDATION')) {
5566 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>';
5568 print
'</tr></table>';
5570 if ($action ==
'editinvoicedate') {
5571 $form->form_date($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id,
$object->date,
'invoicedate');
5573 print
'<span class="valuedate">'.dol_print_date(
$object->date,
'day').
'</span>';
5588 print
'<table class="nobordernopadding centpercent"><tr><td>';
5589 print $langs->trans(
'DatePointOfTax');
5592 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>';
5594 print
'</tr></table>';
5596 if ($action ==
'editdate_pointoftax' && $editable) {
5597 $form->form_date($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id,
$object->date_pointoftax,
'date_pointoftax');
5599 print
'<span class="valuedate">'.dol_print_date(
$object->date_pointoftax,
'day').
'</span>';
5607 print $form->editfieldkey(
'Source',
'input_reason',
'', $object, (
int) $usercancreate);
5608 print
'</td><td class="valuefield">';
5609 if ($action ==
'editinput_reason') {
5610 $form->formInputReason($_SERVER[
'PHP_SELF'].
'?id='.
$object->id, (
string)
$object->demand_reason_id,
'input_reason_id', 1,
'maxwidth250 widthcentpercentminusx');
5612 $form->formInputReason($_SERVER[
'PHP_SELF'].
'?id='.
$object->id, (
string)
$object->demand_reason_id,
'none');
5619 print
'<table class="nobordernopadding centpercent"><tr><td>';
5620 print $langs->trans(
'PaymentConditionsShort');
5623 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>';
5625 print
'</tr></table>';
5628 if ($action ==
'editconditions') {
5629 $form->form_conditions_reglement($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, (
string)
$object->cond_reglement_id,
'cond_reglement_id');
5631 $form->form_conditions_reglement($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, (
string)
$object->cond_reglement_id,
'none');
5638 print
'<table class="nobordernopadding centpercent"><tr><td>';
5639 print $langs->trans(
'DateMaxPayment');
5642 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>';
5644 print
'</tr></table>';
5647 if ($action ==
'editpaymentterm') {
5648 $form->form_date($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id,
$object->date_lim_reglement,
'paymentterm');
5650 print
'<span class="valuedate">'.dol_print_date(
$object->date_lim_reglement,
'day').
'</span>';
5660 print
'<table class="nobordernopadding centpercent"><tr><td>';
5661 print $langs->trans(
'PaymentMode');
5663 if ($action !=
'editmode' && $usercancreate) {
5664 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>';
5666 print
'</tr></table>';
5668 if ($action ==
'editmode') {
5669 $form->form_modes_reglement($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, (
string)
$object->mode_reglement_id,
'mode_reglement_id',
'CRDT', 1, 1);
5671 $form->form_modes_reglement($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, (
string)
$object->mode_reglement_id,
'none',
'CRDT');
5677 print
'<tr><td class="nowrap">';
5678 print
'<table class="nobordernopadding centpercent"><tr><td class="nowrap">';
5679 print $langs->trans(
'DefaultBankAccount');
5681 if (($action !=
'editbankaccount') && $usercancreate) {
5682 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>';
5684 print
'</tr></table>';
5686 if ($action ==
'editbankaccount') {
5687 $form->formSelectAccount($_SERVER[
'PHP_SELF'].
'?id='.
$object->id, (
string)
$object->fk_account,
'fk_account', 1);
5689 $form->formSelectAccount($_SERVER[
'PHP_SELF'].
'?id='.
$object->id, (
string)
$object->fk_account,
'none');
5698 print
'<table class="nobordernopadding centpercent"><tr><td>';
5699 print $langs->trans(
'IncotermLabel');
5700 print
'<td><td class="right">';
5701 if ($usercancreate) {
5702 print
'<a class="editfielda" href="'.DOL_URL_ROOT.
'/compta/facture/card.php?facid='.
$object->id.
'&action=editincoterm&token='.newToken().
'">'.
img_edit().
'</a>';
5704 print
'</td></tr></table>';
5707 if ($action !=
'editincoterm') {
5708 print $form->textwithpicto(
$object->display_incoterms(),
$object->label_incoterms, 1);
5710 print $form->select_incoterms((!empty(
$object->fk_incoterms) ?
$object->fk_incoterms :
''), (!empty(
$object->location_incoterms) ?
$object->location_incoterms :
''), $_SERVER[
'PHP_SELF'].
'?id='.
$object->id);
5717 print
'<table class="nobordernopadding centpercent"><tr><td>';
5718 print $langs->trans(
'Dispute');
5719 print
'<td><td class="right">';
5720 if ($usercancreate) {
5721 print
'<a class="editfielda" href="'.DOL_URL_ROOT.
'/compta/facture/card.php?facid='.
$object->id.
'&action=editdispute_status&token='.newToken().
'">'.
img_edit().
'</a>';
5723 print
'</td></tr></table>';
5725 $liststatus = Facture::ARRAY_OF_DISPUTE_STATUS;
5726 if ($action !=
'editdispute_status') {
5727 if (
$object->dispute_status) {
5728 print $langs->trans($liststatus[
$object->dispute_status][
'label']);
5731 print
'<form enctype="multipart/form-data" action="'.DOL_URL_ROOT.
'/compta/facture/card.php" method="POST">';
5732 print
'<input type="hidden" name="action" value="set_dispute_status">';
5733 print
'<input type="hidden" name="token" value="'.newToken().
'">';
5734 print
'<input type="hidden" name="id" value="'.$object->id.
'">';
5735 print
'<input type="hidden" name="page_y" value="">';
5736 print $form->selectarray(
'dispute_status', $liststatus,
$object->dispute_status, 0, 0, 0,
'', 1);
5737 print
'<input type="submit" class="button smallpaddingimp valignmiddle" value="'.$langs->trans(
"Save").
'">';
5745 print
'<table class="nobordernopadding centpercent"><tr><td>';
5746 print $langs->trans(
"Categories");
5747 print
'<td><td class="right">';
5748 if ($usercancreate) {
5749 print
'<a class="editfielda" href="'.DOL_URL_ROOT.
'/compta/facture/card.php?facid='.
$object->id.
'&action=edittags&token='.newToken().
'">'.
img_edit().
'</a>';
5753 print
'</td></tr></table>';
5756 if ($action ==
'edittags') {
5757 print
'<form method="POST" action="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'">';
5758 print
'<input type="hidden" name="action" value="settags">';
5759 print
'<input type="hidden" name="token" value="'.newToken().
'">';
5760 print $form->selectCategories(Categorie::TYPE_INVOICE,
'categories', $object);
5761 print
'<input type="submit" class="button valignmiddle smallpaddingimp" value="'.$langs->trans(
"Modify").
'">';
5764 print $form->showCategories(
$object->id, Categorie::TYPE_INVOICE, 1);
5769 $displayWarranty =
false;
5772 $displayWarranty =
true;
5773 if (!in_array(
$object->type, $retainedWarrantyInvoiceAvailableType) && empty(
$object->retained_warranty)) {
5774 $displayWarranty =
false;
5777 if ($displayWarranty) {
5779 print
'<tr class="retained-warranty-lines" ><td>';
5780 print
'<table id="retained-warranty-table" class="nobordernopadding centpercent"><tr><td>';
5781 print $langs->trans(
'RetainedWarranty');
5784 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>';
5787 print
'</tr></table>';
5790 print
'<form id="retained-warranty-form" method="POST" action="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'">';
5791 print
'<input type="hidden" name="action" value="setretainedwarranty">';
5792 print
'<input type="hidden" name="token" value="'.newToken().
'">';
5793 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
5794 print
'<input name="retained_warranty" type="number" step="0.01" min="0" max="100" value="'.$object->retained_warranty.
'" >';
5795 print
'<input type="submit" class="button valignmiddle smallpaddingimp" value="'.$langs->trans(
"Modify").
'">';
5803 print
'<tr class="retained-warranty-lines" ><td>';
5804 print
'<table id="retained-warranty-cond-reglement-table" class="nobordernopadding" width="100%"><tr><td>';
5805 print $langs->trans(
'PaymentConditionsShortRetainedWarranty');
5807 if ($action !=
'editretainedwarrantypaymentterms' && $user->hasRight(
'facture',
'creer') &&
$object->status ==
Facture::STATUS_DRAFT) {
5808 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>';
5811 print
'</tr></table>';
5813 $defaultDate = !empty(
$object->retained_warranty_date_limit) ?
$object->retained_warranty_date_limit : strtotime(
'-1 years',
$object->date_lim_reglement);
5814 if (
$object->date > $defaultDate) {
5820 print
'<form method="POST" action="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'">';
5821 print
'<input type="hidden" name="action" value="setretainedwarrantyconditions">';
5822 print
'<input type="hidden" name="token" value="'.newToken().
'">';
5823 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
5824 $retained_warranty_fk_cond_reglement =
GETPOSTINT(
'retained_warranty_fk_cond_reglement');
5825 $retained_warranty_fk_cond_reglement = !empty($retained_warranty_fk_cond_reglement) ? $retained_warranty_fk_cond_reglement :
$object->retained_warranty_fk_cond_reglement;
5826 $retained_warranty_fk_cond_reglement = !empty($retained_warranty_fk_cond_reglement) ? $retained_warranty_fk_cond_reglement :
getDolGlobalString(
'INVOICE_SITUATION_DEFAULT_RETAINED_WARRANTY_COND_ID');
5827 print $form->getSelectConditionsPaiements($retained_warranty_fk_cond_reglement,
'retained_warranty_fk_cond_reglement', -1, 1);
5828 print
'<input type="submit" class="button valignmiddle" value="'.$langs->trans(
"Modify").
'">';
5831 $form->form_conditions_reglement($_SERVER[
'PHP_SELF'].
'?facid='.
$object->id, (
string)
$object->retained_warranty_fk_cond_reglement,
'none');
5832 if (!$displayWarranty) {
5833 print
img_picto($langs->trans(
'RetainedWarrantyNeed100Percent'),
'warning',
'class="pictowarning valignmiddle" ');
5839 print
'<tr class="retained-warranty-lines" ><td>';
5840 print
'<table id="retained-warranty-date-limit-table" class="nobordernopadding" width="100%"><tr><td>';
5841 print $langs->trans(
'RetainedWarrantyDateLimit');
5844 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>';
5847 print
'</tr></table>';
5849 $defaultDate = !empty(
$object->retained_warranty_date_limit) ?
$object->retained_warranty_date_limit : strtotime(
'-1 years',
$object->date_lim_reglement);
5850 if (
$object->date > $defaultDate) {
5855 print
'<form method="POST" action="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'">';
5856 print
'<input type="hidden" name="action" value="setretainedwarrantydatelimit">';
5857 print
'<input type="hidden" name="token" value="'.newToken().
'">';
5858 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
5860 print $form->selectDate($defaultDate,
'retained_warranty_date_limit');
5861 print
'<input type="submit" class="button valignmiddle" value="'.$langs->trans(
"Modify").
'">';
5873 include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_view.tpl.php';
5878 print
'<div class="fichehalfright">';
5880 print
'<!-- amounts -->'.
"\n";
5881 print
'<div class="underbanner clearboth"></div>'.
"\n";
5883 print
'<table class="border tableforfield centpercent">';
5885 include DOL_DOCUMENT_ROOT.
'/core/tpl/object_currency_amount.tpl.php';
5893 print
'<td class="titlefieldmiddle">' . $langs->trans(
'AmountHT') .
'</td>';
5894 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->total_ht, 0, $langs, 0, -1, -1,
$conf->currency) .
'</td>';
5897 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->multicurrency_total_ht, 0, $langs, 0, -1, -1,
$object->multicurrency_code) .
'</td>';
5903 print
'<td>' . $langs->trans(
'AmountVAT') .
'</td>';
5904 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->total_tva, 0, $langs, 0, -1, -1,
$conf->currency) .
'</td>';
5907 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->multicurrency_total_tva, 0, $langs, 0, -1, -1,
$object->multicurrency_code) .
'</td>';
5912 if ((
$mysoc->localtax1_assuj ==
"1" &&
$mysoc->useLocalTax(1)) ||
$object->total_localtax1 != 0) {
5914 print
'<td class="titlefieldmiddle">' . $langs->transcountry(
"AmountLT1",
$mysoc->country_code) .
'</td>';
5915 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->total_localtax1, 0, $langs, 0, -1, -1,
$conf->currency) .
'</td>';
5919 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->multicurrency_total_localtax1, 0, $langs, 0, -1, -1,
$object->multicurrency_code) .
'</td>';
5924 if ((
$mysoc->localtax2_assuj ==
"1" &&
$mysoc->useLocalTax(2)) ||
$object->total_localtax2 != 0) {
5926 print
'<td>' . $langs->transcountry(
"AmountLT2",
$mysoc->country_code) .
'</td>';
5927 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->total_localtax2, 0, $langs, 0, -1, -1,
$conf->currency) .
'</td>';
5931 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->multicurrency_total_localtax2, 0, $langs, 0, -1, -1,
$object->multicurrency_code) .
'</td>';
5937 if ($selleruserevenustamp) {
5938 print
'<tr><td class="titlefieldmiddle">';
5939 print
'<table class="nobordernopadding centpercent"><tr><td>';
5940 print $langs->trans(
'RevenueStamp');
5942 if ($action !=
'editrevenuestamp' &&
$object->status == $object::STATUS_DRAFT && $usercancreate) {
5943 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>';
5945 print
'</tr></table>';
5946 print
'</td><td class="nowrap amountcard right">';
5947 if ($action ==
'editrevenuestamp') {
5948 print
'<form action="'.$_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'" method="post">';
5949 print
'<input type="hidden" name="token" value="'.newToken().
'">';
5950 print
'<input type="hidden" name="action" value="setrevenuestamp">';
5951 print
'<input type="hidden" name="revenuestamp" id="revenuestamp_val" value="'.price2num(
$object->revenuestamp).
'">';
5952 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
5953 print $formother->select_revenue_stamp(
'',
'revenuestamp_type',
$mysoc->country_code);
5954 print
' → <span id="revenuestamp_span"></span>';
5955 print
' <input type="submit" class="button buttongen button-save small" value="'.$langs->trans(
'Modify').
'">';
5958 $(document).ready(function(){
5959 js_recalculate_revenuestamp();
5960 $('select[name=revenuestamp_type]').on('change',function(){
5961 js_recalculate_revenuestamp();
5964 function js_recalculate_revenuestamp(){
5965 var valselected = $('select[name=revenuestamp_type]').val();
5966 console.log('Calculate revenue stamp from '+valselected);
5968 if (valselected.indexOf('%') == -1)
5970 revenue = valselected;
5974 var revenue_type = parseFloat(valselected);
5975 var amount_net = ".round(
$object->total_ht, 2).
";
5976 revenue = revenue_type * amount_net / 100;
5977 revenue = revenue.toFixed(2);
5979 $('#revenuestamp_val').val(revenue);
5980 $('#revenuestamp_span').html(revenue);
5991 print
'<td>' . $langs->trans(
'AmountTTC') .
'</td>';
5992 print
'<td class="nowraponall amountcard right">' .
price($sign *
$object->total_ttc, 0, $langs, 0, -1, -1,
$conf->currency) .
'</td>';
5995 print
'<td class="nowrap amountcard right">' .
price($sign *
$object->multicurrency_total_ttc, 0, $langs, 0, -1, -1,
$object->multicurrency_code) .
'</td>';
6010 if (
$mysoc->localtax1_assuj ==
"1" ||
$object->total_localtax1 != 0) {
6013 if (
$mysoc->localtax2_assuj ==
"1" ||
$object->total_localtax2 != 0) {
6016 if ($selleruserevenustamp) {
6026 $total_prev_ht = $total_prev_ttc = 0;
6027 $total_global_ht = $total_global_ttc = 0;
6031 print
'<!-- List of situation invoices -->';
6032 print
'<div class="div-table-responsive-no-min">';
6033 print
'<table class="noborder paymenttable centpercent situationstable">';
6035 print
'<tr class="liste_titre">';
6036 print
'<td>'.$langs->trans(
'ListOfSituationInvoices').
'</td>';
6038 print
'<td class="center">'.$langs->trans(
'Situation').
'</td>';
6041 print
'<td class="right"></td>';
6043 print
'<td class="right">'.$langs->trans(
'AmountHT').
'</td>';
6044 print
'<td class="right">'.$langs->trans(
'AmountTTC').
'</td>';
6045 print
'<td width="18"> </td>';
6048 if (count(
$object->tab_previous_situation_invoice) > 0) {
6051 $current_situation_counter = array();
6052 foreach (
$object->tab_previous_situation_invoice as $prev_invoice) {
6053 $tmptotalallpayments = $prev_invoice->getSommePaiement(0);
6054 $tmptotalallpayments += $prev_invoice->getSumDepositsUsed(0);
6055 $tmptotalallpayments += $prev_invoice->getSumCreditNotesUsed(0);
6057 $total_prev_ht += $prev_invoice->total_ht;
6058 $total_prev_ttc += $prev_invoice->total_ttc;
6060 $current_situation_counter[] = (($prev_invoice->type ==
Facture::TYPE_CREDIT_NOTE) ? -1 : 1) * $prev_invoice->situation_counter;
6061 print
'<tr class="oddeven">';
6062 print
'<td>'.$prev_invoice->getNomUrl(1).
'</td>';
6064 print
'<td align="center" >'.(($prev_invoice->type ==
Facture::TYPE_CREDIT_NOTE) ? $langs->trans(
'situationInvoiceShortcode_AS') : $langs->trans(
'situationInvoiceShortcode_S')).$prev_invoice->situation_counter.
'</td>';
6066 print
'<td class="right"></td>';
6068 print
'<td class="right"><span class="amount">'.price($prev_invoice->total_ht).
'</span></td>';
6069 print
'<td class="right"><span class="amount">'.price($prev_invoice->total_ttc).
'</span></td>';
6070 print
'<td class="right">'.$prev_invoice->getLibStatut(3, $tmptotalallpayments).
'</td>';
6075 $totalallpayments =
$object->getSommePaiement(0);
6076 $totalallpayments +=
$object->getSumCreditNotesUsed(0);
6077 $totalallpayments +=
$object->getSumDepositsUsed(0);
6079 $total_global_ht += $total_prev_ht;
6080 $total_global_ttc += $total_prev_ttc;
6081 $total_global_ht +=
$object->total_ht;
6082 $total_global_ttc +=
$object->total_ttc;
6086 print
'<tr class="oddeven">';
6087 print
'<td>'.$object->getNomUrl(1).
'</td>';
6089 print
'<td class="center">'.(($object->type ==
Facture::TYPE_CREDIT_NOTE) ? $langs->trans(
'situationInvoiceShortcode_AS') : $langs->trans(
'situationInvoiceShortcode_S')).
$object->situation_counter.
'</td>';
6091 print
'<td class="right"></td>';
6093 print
'<td class="right"><span class="amount">'.price(
$object->total_ht).
'</span></td>';
6094 print
'<td class="right"><span class="amount">'.price(
$object->total_ttc).
'</span></td>';
6095 print
'<td class="right">'.$object->getLibStatut(3, $totalallpayments).
'</td>';
6099 print
'<tr class="oddeven">';
6100 print
'<td colspan="2" class="left"><b>'.$langs->trans(
'SituationTotalAfterInvoice').
'</b></td>';
6103 foreach ($current_situation_counter as $sit) {
6104 $curSign = $sit > 0 ?
'+' :
'-';
6105 $curType = $sit > 0 ? $langs->trans(
'situationInvoiceShortcode_S') : $langs->trans(
'situationInvoiceShortcode_AS');
6107 print
' '.$curSign.
' ';
6109 print $curType.abs($sit);
6116 print
'<td class="right"><b>'.price($total_global_ht).
'</b></td>';
6117 print
'<td class="right"><b>'.price($total_global_ttc).
'</b></td>';
6118 print
'<td width="18"> </td>';
6122 if (count(
$object->tab_next_situation_invoice) > 0) {
6124 $total_next_ht = $total_next_ttc = 0;
6126 foreach (
$object->tab_next_situation_invoice as $next_invoice) {
6127 $totalpaid = $next_invoice->getSommePaiement(0);
6128 $totalcreditnotes = $next_invoice->getSumCreditNotesUsed(0);
6129 $totaldeposits = $next_invoice->getSumDepositsUsed(0);
6130 $total_next_ht += $next_invoice->total_ht;
6131 $total_next_ttc += $next_invoice->total_ttc;
6133 print
'<tr class="oddeven">';
6134 print
'<td>'.$next_invoice->getNomUrl(1).
'</td>';
6136 print
'<td class="center">'.(($next_invoice->type ==
Facture::TYPE_CREDIT_NOTE) ? $langs->trans(
'situationInvoiceShortcode_AS') : $langs->trans(
'situationInvoiceShortcode_S')).$next_invoice->situation_counter.
'</td>';
6138 print
'<td class="right"></td>';
6140 print
'<td class="right"><span class="amount">'.price($next_invoice->total_ht).
'</span></td>';
6141 print
'<td class="right"><span class="amount">'.price($next_invoice->total_ttc).
'</span></td>';
6142 print
'<td class="right">'.$next_invoice->getLibStatut(3, $totalpaid + $totalcreditnotes + $totaldeposits).
'</td>';
6146 $total_global_ht += $total_next_ht;
6147 $total_global_ttc += $total_next_ttc;
6149 print
'<tr class="oddeven">';
6150 print
'<td colspan="3" class="right"></td>';
6152 print
'<td class="right"></td>';
6154 print
'<td class="right"><b>'.price($total_global_ht).
'</b></td>';
6155 print
'<td class="right"><b>'.price($total_global_ttc).
'</b></td>';
6156 print
'<td width="18"> </td>';
6165 if (
$object->type == $object::TYPE_CREDIT_NOTE) {
6171 print
'<!-- List of payments already done -->';
6172 print
'<div class="div-table-responsive-no-min">';
6173 print
'<table class="noborder paymenttable centpercent">';
6175 print
'<tr class="liste_titre">';
6176 print
'<td class="liste_titre">'.($object->type ==
Facture::TYPE_CREDIT_NOTE ? $langs->trans(
"PaymentsBack") : $langs->trans(
'Payments')).
'</td>';
6177 print
'<td class="liste_titre"><span class="hideonsmartphone">'.$langs->trans(
'Date').
'</span></td>';
6178 print
'<td class="liste_titre"><span class="hideonsmartphone">'.$langs->trans(
'Type').
'</span></td>';
6180 print
'<td class="liste_titre"><span class="hideonsmartphone">'.$langs->trans(
'BankAccount').
'</span></td>';
6182 print
'<td class="liste_titre"></td>';
6183 print
'<td class="liste_titre right">'.$langs->trans(
'Amount').
'</td>';
6187 $sql =
'SELECT p.datep as dp, p.ref, p.num_paiement as num_payment, p.rowid, p.fk_bank,';
6188 $sql .=
' c.code as payment_code, c.libelle as payment_label,';
6189 $sql .=
' pf.amount,';
6190 $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';
6191 $sql .=
' FROM '.MAIN_DB_PREFIX.
'paiement_facture as pf, '.MAIN_DB_PREFIX.
'paiement as p';
6192 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_paiement as c ON p.fk_paiement = c.id';
6193 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'bank as b ON p.fk_bank = b.rowid';
6194 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'bank_account as ba ON b.fk_account = ba.rowid';
6195 $sql .=
' WHERE pf.fk_facture = '.((int)
$object->id).
' AND pf.fk_paiement = p.rowid';
6196 $sql .=
' AND p.entity IN ('.getEntity(
'invoice').
')';
6197 $sql .=
' ORDER BY p.datep, p.tms';
6199 $result =
$db->query($sql);
6201 $num =
$db->num_rows($result);
6206 $objp =
$db->fetch_object($result);
6208 $paymentstatic->id = $objp->rowid;
6209 $paymentstatic->datepaye =
$db->jdate($objp->dp);
6210 $paymentstatic->ref = $objp->ref;
6211 $paymentstatic->num_payment = $objp->num_payment;
6212 $paymentstatic->paiementcode = $objp->payment_code;
6214 print
'<tr class="oddeven">';
6215 print
'<td class="nowraponall">';
6216 print $paymentstatic->getNomUrl(1);
6219 $dateofpayment =
$db->jdate($objp->dp);
6221 if ($tmparray[
'seconds'] == 0 && $tmparray[
'minutes'] == 0 && ($tmparray[
'hours'] == 0 || $tmparray[
'hours'] == 12)) {
6228 $label = ($langs->trans(
"PaymentType".$objp->payment_code) !=
"PaymentType".$objp->payment_code) ? $langs->trans(
"PaymentType".$objp->payment_code) : $objp->payment_label;
6229 print
'<td class="tdoverflowmax80" title="'.dol_escape_htmltag($label.
' '.$objp->num_payment).
'">'.
dol_escape_htmltag($label.
' '.$objp->num_payment).
'</td>';
6231 $bankaccountstatic->id = $objp->baid;
6232 $bankaccountstatic->ref = $objp->baref;
6233 $bankaccountstatic->label = $objp->baref;
6234 $bankaccountstatic->number = $objp->banumber;
6235 $bankaccountstatic->currency_code = $objp->bacurrency_code;
6238 $bankaccountstatic->account_number = $objp->account_number;
6241 $accountingjournal->fetch($objp->fk_accountancy_journal);
6242 $bankaccountstatic->accountancy_journal = $accountingjournal->getNomUrl(0, 1, 1,
'', 1);
6245 print
'<td class="nowraponall">';
6246 if ($bankaccountstatic->id) {
6247 print $bankaccountstatic->getNomUrl(1,
'transactions');
6253 print
'<td class="center">';
6255 $paiement->fetch($objp->rowid);
6257 print
'<a href="'.$_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'&action=deletepayment&token='.newToken().
'&paiement_id='.$objp->rowid.
'">';
6264 print
'<td class="right"><span class="amount">'.price($sign * $objp->amount).
'</span></td>';
6279 print
'<td colspan="'.($nbcols + 1).
'" class="right">';
6280 print
'<span class="opacitymedium">';
6282 print $langs->trans(
'AlreadyPaidNoCreditNotesNoDeposits');
6284 print $langs->trans(
'AlreadyPaid');
6286 print
'</span></td>';
6288 print
'<td class="right'.(($totalpaid > 0) ?
' amountalreadypaid' :
'').
'">'.
price($totalpaid).
'</td>';
6291 $resteapayeraffiche = $resteapayer;
6292 $cssforamountpaymentcomplete =
'amountpaymentcomplete';
6293 $cssforamountpaymentcompletenoresize =
'amountpaymentcompletenoresize';
6296 $creditnoteamount = 0;
6298 $sql =
"SELECT re.rowid, re.amount_ht, re.amount_tva, re.amount_ttc,";
6299 $sql .=
" re.description, re.fk_facture_source";
6300 $sql .=
" FROM ".MAIN_DB_PREFIX.
"societe_remise_except as re";
6301 $sql .=
" WHERE fk_facture = ".((int)
$object->id);
6302 $resql =
$db->query($sql);
6304 $num =
$db->num_rows($resql);
6308 $obj =
$db->fetch_object($resql);
6309 $invoice->fetch($obj->fk_facture_source);
6311 print
'<td colspan="'.$nbcols.
'" class="right">';
6312 print
'<span class="opacitymedium">';
6314 print $langs->trans(
"CreditNote").
' ';
6317 print $langs->trans(
"Deposit").
' ';
6319 print $invoice->getNomUrl(0);
6323 print
'<td class="right">';
6324 print
'<a href="'.$_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&action=unlinkdiscount&token='.newToken().
'&discountid='.$obj->rowid.
'">';
6325 print
img_picto($langs->transnoentitiesnoconv(
"RemoveDiscount"),
'unlink');
6329 print
'<td class="right"><span class="amount">'.price($obj->amount_ttc).
'</span></td>';
6333 $creditnoteamount += $obj->amount_ttc;
6336 $depositamount += $obj->amount_ttc;
6346 print
'<td colspan="'.$nbcols.
'" class="nowrap right">';
6347 print
'<span class="opacitymedium">';
6348 print $form->textwithpicto($langs->trans(
"Discount"), $langs->trans(
"HelpEscompte"), - 1);
6352 print
'<td class="right"><span class="amount">'.price(
price2num(
$object->total_ttc - $creditnoteamount - $depositamount - $totalpaid,
'MT')).
'</span></td>';
6354 $resteapayeraffiche = 0;
6355 $cssforamountpaymentcomplete =
'amountpaymentneutral';
6356 $cssforamountpaymentcompletenoresize =
'amountpaymentneutralnoresize';
6361 print
'<td colspan="'.($nbcols + 1).
'" class="nowrap right">';
6362 print
'<span class="opacitymedium">';
6363 print $form->textwithpicto($langs->trans(
"Abandoned"), $langs->trans(
"HelpAbandonBadCustomer"), - 1);
6367 print
'<td class="right">'.price(
price2num(
$object->total_ttc - $creditnoteamount - $depositamount - $totalpaid,
'MT')).
'</td>';
6370 $cssforamountpaymentcomplete =
'amountpaymentneutral';
6371 $cssforamountpaymentcompletenoresize =
'amountpaymentneutralnoresize';
6376 print
'<td colspan="'.($nbcols + 1).
'" class="nowrap right">';
6377 print
'<span class="opacitymedium">';
6378 print $form->textwithpicto($langs->trans(
"ProductReturned"), $langs->trans(
"HelpAbandonProductReturned"), - 1);
6382 print
'<td class="right"><span class="amount">'.price(
price2num(
$object->total_ttc - $creditnoteamount - $depositamount - $totalpaid,
'MT')).
'</span></td>';
6384 $resteapayeraffiche = 0;
6385 $cssforamountpaymentcomplete =
'amountpaymentneutral';
6386 $cssforamountpaymentcompletenoresize =
'amountpaymentneutralnoresize';
6391 print
'<td colspan="'.($nbcols + 1).
'" class="nowrap right">';
6392 $text = $langs->trans(
"HelpAbandonOther");
6394 $text .=
'<br><br><b>'.$langs->trans(
"Reason").
'</b>:'.
$object->close_note;
6396 print
'<span class="opacitymedium">';
6398 print $form->textwithpicto($langs->trans(
"Abandoned"), $text, - 1);
6402 print
'<td class="right"><span class="amount">'.price(
price2num(
$object->total_ttc - $creditnoteamount - $depositamount - $totalpaid,
'MT')).
'</span></td>';
6404 $resteapayeraffiche = 0;
6405 $cssforamountpaymentcomplete =
'amountpaymentneutral';
6406 $cssforamountpaymentcompletenoresize =
'amountpaymentneutralnoresize';
6411 print
'<td colspan="'.($nbcols + 1).
'" class="right">';
6412 print
'<span class="opacitymedium">';
6413 print $langs->trans(
"Billed");
6416 print
'<td class="right">'.price(
$object->total_ttc).
'</td>';
6421 print
'<td colspan="'.($nbcols + 1).
'" class="right">';
6422 print
'<span class="opacitymedium">';
6423 print $langs->trans(
'RemainderToPay');
6424 if ($resteapayeraffiche < 0) {
6425 print
' ('.$langs->trans(
'NegativeIfExcessReceived').
')';
6430 print
'<td class="right'.($resteapayeraffiche ?
' amountremaintopay' : (
' '.$cssforamountpaymentcomplete)).
'">'.
price($resteapayeraffiche).
'</td>';
6436 print
'<td colspan="'.($nbcols + 1).
'" class="right">';
6437 print
'<span class="opacitymedium">';
6438 print $langs->trans(
'RemainderToPayMulticurrency');
6439 if ($resteapayeraffiche < 0) {
6440 print
' ('.$langs->trans(
'NegativeIfExcessReceived').
')';
6445 print
'<td class="right'.($resteapayeraffiche ?
' amountremaintopaynoresize' : (
' '.$cssforamountpaymentcompletenoresize)).
'">';
6452 if (!empty(
$object->situation_final) && !empty(
$object->retained_warranty) && $displayWarranty) {
6454 if (
$object->isSituationInvoice()) {
6455 $retainedWarranty = $total_global_ttc *
$object->retained_warranty / 100;
6458 $retainedWarranty =
$object->total_ttc *
$object->retained_warranty / 100;
6461 $billedWithRetainedWarranty =
$object->total_ttc - $retainedWarranty;
6464 print
'<td colspan="'.($nbcols + 1).
'" class="right">'.$langs->trans(
"ToPayOn",
dol_print_date(
$object->date_lim_reglement,
'day')).
' :</td>';
6466 print
'<td class="right">'.price($billedWithRetainedWarranty).
'</td>';
6471 print
'<td colspan="'.($nbcols + 1).
'" class="right">';
6472 print $langs->trans(
"RetainedWarranty").
' ('.
$object->retained_warranty.
'%)';
6473 print !empty(
$object->retained_warranty_date_limit) ?
' '.$langs->trans(
"ToPayOn",
dol_print_date(
$object->retained_warranty_date_limit,
'day')) :
'';
6476 print
'<td class="right">'.price($retainedWarranty).
'</td>';
6480 $resteapayeraffiche = $resteapayer;
6481 $cssforamountpaymentcomplete =
'amountpaymentneutral';
6482 $cssforamountpaymentcompletenoresize =
'amountpaymentneutralnoresize';
6486 print
'<td colspan="'.($nbcols + 1).
'" class="right">';
6487 print
'<span class="opacitymedium">'.$langs->trans(
'AlreadyPaidBack').
'</span>';
6490 print
'<td class="right"><span class="amount">'.price($sign * $totalpaid).
'</span></td>';
6495 print
'<td colspan="'.($nbcols + 1).
'" class="right"><span class="opacitymedium">'.$langs->trans(
"Billed").
'</span></td>';
6497 print
'<td class="right">'.price($sign *
$object->total_ttc).
'</td>';
6501 print
'<tr><td colspan="'.($nbcols + 1).
'" class="right">';
6502 print
'<span class="opacitymedium">'.$langs->trans(
'RemainderToPayBack');
6503 if ($resteapayeraffiche > 0) {
6504 print
' ('.$langs->trans(
'NegativeIfExcessRefunded').
')';
6506 print
'</span></td>';
6508 print
'<td class="right'.($resteapayeraffiche ?
' amountremaintopayback' : (
' '.$cssforamountpaymentcomplete)).
'">'.
price($sign * $resteapayeraffiche);
6517 print
'<td colspan="'.($nbcols + 1).
'" class="right">';
6518 print
'<span class="opacitymedium">'.$langs->trans(
'RemainderToPayBackMulticurrency');
6519 if ($resteapayeraffiche > 0) {
6520 print
' ('.$langs->trans(
'NegativeIfExcessRefunded').
')';
6525 print
'<td class="right'.($resteapayeraffiche ?
' amountremaintopaybacknoresize' : (
' '.$cssforamountpaymentcompletenoresize)).
'">'.
price(
price2num($sign *
$object->multicurrency_tx * $resteapayeraffiche,
'MT'), 1, $langs, 1, -1, -1, (empty(
$object->multicurrency_code) ?
$conf->currency :
$object->multicurrency_code)).
'</td>';
6540 $formmargin->displayMarginInfos($object);
6546 print
'<div class="clearboth"></div><br>';
6549 $blocname =
'contacts';
6550 $title = $langs->trans(
'ContactsAddresses');
6551 include DOL_DOCUMENT_ROOT.
'/core/tpl/bloc_showhide.tpl.php';
6555 $blocname =
'notes';
6556 $title = $langs->trans(
'Notes');
6557 include DOL_DOCUMENT_ROOT.
'/core/tpl/bloc_showhide.tpl.php';
6561 $result =
$object->getLinesArray();
6565 global $inputalsopricewithtax;
6566 $inputalsopricewithtax = 1;
6571 print
'<!-- Area to change globally the situation percent -->'.
"\n";
6572 print
'<div class="div-table-responsive-no-min">';
6574 print
'<form name="updatealllines" id="updatealllines" action="'.$_SERVER[
'PHP_SELF'].
'?id='.
$object->id.
'#updatealllines" method="POST">';
6575 print
'<input type="hidden" name="token" value="'.newToken().
'" />';
6576 print
'<input type="hidden" name="action" value="updatealllines" />';
6577 print
'<input type="hidden" name="id" value="'.$object->id.
'" />';
6578 print
'<input type="hidden" name="page_y" value="" />';
6579 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
6581 print
'<table id="tablelines_all_progress" class="noborder noshadow centpercent">';
6583 print
'<tr class="liste_titre nodrag nodrop">';
6587 print
'<td align="center" width="5"> </td>';
6589 print
'<td class="minwidth500imp">'.$langs->trans(
'ModifyAllLines').
'</td>';
6590 print
'<td class="right">'.$langs->trans(
'CumulativeProgression').
'</td>';
6591 print
'<td> </td>';
6594 print
'<tr class="nodrag nodrop">';
6597 print
'<td align="center" width="5"> </td>';
6599 print
'<td> </td>';
6600 print
'<td class="nowrap right"><input type="text" size="1" value="" name="all_progress">%</td>';
6601 print
'<td class="right"><input type="submit" class="button reposition small" name="all_percent" value="'.$langs->trans(
"Modify").
'" /></td>';
6612 print
' <form name="addproduct" id="addproduct" action="'.$_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'" method="POST">
6613 <input type="hidden" name="token" value="' . newToken().
'">
6614 <input type="hidden" name="action" value="' . (($action !=
'editline') ?
'addline' :
'updateline').
'">
6615 <input type="hidden" name="mode" value="">
6616 <input type="hidden" name="page_y" value="">
6617 <input type="hidden" name="id" value="' .
$object->id.
'">
6618 <input type="hidden" name="backtopage" value="'.$backtopage.
'">
6621 if (!empty(
$conf->use_javascript_ajax) &&
$object->status == 0) {
6623 include DOL_DOCUMENT_ROOT.
'/core/tpl/subtotal_ajaxrow.tpl.php';
6625 include DOL_DOCUMENT_ROOT .
'/core/tpl/ajaxrow.tpl.php';
6629 print
'<div class="div-table-responsive-no-min">';
6630 print
'<table id="tablelines" class="noborder noshadow centpercent nomarginbottom">';
6634 $object->printObjectLines($action,
$mysoc, $soc, $lineid, 1);
6638 if (
$object->status == 0 && $usercancreate && $action !=
'valid') {
6639 if ($action !=
'editline' && $action !=
'selectlines') {
6642 $parameters = array();
6643 $reshook = $hookmanager->executeHooks(
'formAddObjectLine', $parameters, $object, $action);
6647 if (empty($reshook)) {
6651 $parameters = array();
6652 $reshook = $hookmanager->executeHooks(
'formEditObjectLine', $parameters, $object, $action);
6666 if ($action !=
'prerelance' && $action !=
'presend' && $action !=
'valid' && $action !=
'editline') {
6667 print
'<div class="tabsAction">';
6669 $parameters = array();
6670 $reshook = $hookmanager->executeHooks(
'addMoreActionsButtons', $parameters, $object, $action);
6671 if (empty($reshook)) {
6674 'class' =>
'classfortooltip',
6681 $ventilExportCompta =
$object->getVentilExportCompta();
6683 if ($ventilExportCompta == 0) {
6685 if (!$objectidnext &&
$object->is_last_in_cycle()) {
6686 if ($usercanunvalidate) {
6687 unset($params[
'attr'][
'title']);
6688 print dolGetButtonAction($langs->trans(
'Modify'),
'',
'default', $_SERVER[
'PHP_SELF'] .
'?facid=' .
$object->id .
'&action=modif&token=' . newToken(),
'',
true, $params);
6690 $params[
'attr'][
'title'] = $langs->trans(
'NotEnoughPermissions');
6691 print dolGetButtonAction($langs->trans(
'Modify'),
'',
'default', $_SERVER[
'PHP_SELF'] .
'?facid=' .
$object->id .
'&action=modif&token=' . newToken(),
'',
false, $params);
6693 } elseif (!
$object->is_last_in_cycle()) {
6694 $params[
'attr'][
'title'] = $langs->trans(
'NotLastInCycle');
6695 print dolGetButtonAction($langs->trans(
'Modify'),
'',
'default',
'#',
'',
false, $params);
6697 $params[
'attr'][
'title'] = $langs->trans(
'DisabledBecauseReplacedInvoice');
6698 print dolGetButtonAction($langs->trans(
'Modify'),
'',
'default',
'#',
'',
false, $params);
6702 $params[
'attr'][
'title'] = $langs->trans(
'DisabledBecauseDispatchedInBookkeeping');
6703 print dolGetButtonAction($langs->trans(
'Modify'),
'',
'default',
'#',
'',
false, $params);
6708 $result = $discount->fetch(0,
$object->id);
6716 && ((!
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $usercancreate) || $usercanreopen)) {
6717 if (
$object->close_code !=
'replaced' || (!$objectidnext)) {
6718 unset($params[
'attr'][
'title']);
6719 print dolGetButtonAction($langs->trans(
'ReOpen'),
'',
'default', $_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=reopen&token='.newToken(),
'',
true, $params);
6721 $params[
'attr'][
'title'] = $langs->trans(
"DisabledBecauseReplacedInvoice");
6722 print dolGetButtonAction($langs->trans(
'ReOpen'),
'',
'default',
'#',
'',
false, $params);
6729 $langs->load(
"contracts");
6731 if ($usercancreatecontract) {
6732 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>';
6740 $langs->load(
"subtotals");
6742 $url_button = array();
6744 $url_button[] = array(
6745 'lang' =>
'subtotals',
6747 'perm' => (
bool) $usercancreate,
6748 'label' => $langs->trans(
'AddTitleLine'),
6749 'url' =>
'/compta/facture/card.php?facid='.$object->id.
'&action=add_title_line&token='.newToken()
6752 $url_button[] = array(
6753 'lang' =>
'subtotals',
6755 'perm' => (
bool) $usercancreate,
6756 'label' => $langs->trans(
'AddSubtotalLine'),
6757 'url' =>
'/compta/facture/card.php?facid='.$object->id.
'&action=add_subtotal_line&token='.newToken()
6759 print dolGetButtonAction(
'', $langs->trans(
'Subtotal'),
'default', $url_button,
'',
true);
6766 if ($usercanvalidate) {
6767 unset($params[
'attr'][
'title']);
6768 print dolGetButtonAction($langs->trans(
'Validate'),
'',
'default', $_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&action=valid&token='.newToken(),
'',
true, $params);
6773 if (empty($user->socid)) {
6775 if ($objectidnext) {
6776 $params[
'attr'][
'title'] = $langs->trans(
"DisabledBecauseReplacedInvoice");
6777 print dolGetButtonAction(
'', $langs->trans(
'SendMail'),
'email',
'#',
'',
false, $params);
6780 unset($params[
'attr'][
'title']);
6781 print dolGetButtonAction(
'', $langs->trans(
'SendMail'),
'email', $_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=presend&mode=init#formmailbeforetitle',
'',
true, $params);
6783 unset($params[
'attr'][
'title']);
6784 print dolGetButtonAction(
'', $langs->trans(
'SendMail'),
'email',
'#',
'',
false, $params);
6792 if ($resteapayer > 0) {
6793 if ($usercancreatewithdrarequest) {
6794 if (!$objectidnext &&
$object->close_code !=
'replaced') {
6795 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>';
6797 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"DisabledBecauseReplacedInvoice").
'">'.$langs->trans(
'MakeWithdrawRequest').
'</span>';
6809 $langs->load(
"cashdesk");
6810 $receipt_url = DOL_URL_ROOT.
"/takepos/receipt.php";
6811 print
'<a target="_blank" rel="noopener noreferrer" class="butAction" href="'.$receipt_url.
'?facid='.((int)
$object->id).
'">'.$langs->trans(
'POSTicket').
'</a>';
6816 if ($objectidnext) {
6817 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"DisabledBecauseReplacedInvoice").
'">'.$langs->trans(
'DoPayment').
'</span>';
6821 $params[
'attr'][
'title'] = $langs->trans(
'DisabledBecauseRemainderToPayIsZero');
6822 print dolGetButtonAction($langs->trans(
'DoPayment'),
'',
'default',
'#',
'',
false, $params);
6826 unset($params[
'attr'][
'title']);
6827 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);
6832 $sumofpayment = $totalpaid;
6833 $sumofpaymentall = $totalpaid + $totalcreditnotes + $totaldeposits;
6839 if ($resteapayer == 0) {
6840 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"DisabledBecauseRemainderToPayIsZero").
'">'.$langs->trans(
'DoPaymentBack').
'</span>';
6842 print
'<a class="butAction" href="'.DOL_URL_ROOT.
'/compta/paiement.php?facid='.
$object->id.
'&action=create&accountid='.
$object->fk_account.
'">'.$langs->trans(
'DoPaymentBack').
'</a>';
6848 print
'<a class="butAction'.($conf->use_javascript_ajax ?
' reposition' :
'').
'" href="'.$_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&action=converttoreduc&token='.newToken().
'">'.$langs->trans(
'ConvertExcessReceivedToReduc').
'</a>';
6852 && (
getDolGlobalString(
'INVOICE_ALLOW_REUSE_OF_CREDIT_WHEN_PARTIALLY_REFUNDED') || $sumofpayment == 0) &&
$object->total_ht < 0
6854 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>';
6861 print
'<a class="butAction'.($conf->use_javascript_ajax ?
' reposition' :
'').
'" href="'.$_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&action=converttoreduc&token='.newToken().
'">'.$langs->trans(
'ConvertToReduc').
'</a>';
6863 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"AmountPaidMustMatchAmountOfDownPayment").
'">'.$langs->trans(
'ConvertToReduc').
'</span>';
6877 $params[
'attr'][
'title'] = $langs->trans(
'AmountPaidMustMatchAmountOfDownPayment');
6878 print dolGetButtonAction($langs->trans(
'ClassifyPaid'),
'',
'default',
'#',
'',
false, $params);
6880 unset($params[
'attr'][
'title']);
6881 print dolGetButtonAction($langs->trans(
'ClassifyPaid'),
'',
'default', $_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=paid&token='.newToken(),
'',
true, $params);
6887 if ($totalpaid > 0 || $totalcreditnotes > 0) {
6889 print
'<a class="butAction'.($conf->use_javascript_ajax ?
' reposition' :
'').
'" href="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=paid&token='.newToken().
'">'.$langs->trans(
'ClassifyPaidPartially').
'</a>';
6892 if ($objectidnext) {
6893 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"DisabledBecauseReplacedInvoice").
'">'.$langs->trans(
'ClassifyCanceled').
'</span>';
6895 print
'<a class="butAction'.($conf->use_javascript_ajax ?
' reposition' :
'').
'" href="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=canceled">'.$langs->trans(
'ClassifyCanceled').
'</a>';
6902 if ($usercancreate &&
$object->isSituationInvoice() && (
$object->status == 1 ||
$object->status == 2)) {
6903 if (
$object->is_last_in_cycle() &&
$object->situation_final != 1) {
6904 print
'<a class="butAction" href="'.$_SERVER[
'PHP_SELF'].
'?action=create&type=5&origin=facture&originid='.
$object->id.
'&socid='.
$object->socid.
'" >'.$langs->trans(
'CreateNextSituationInvoice').
'</a>';
6905 } elseif (!
$object->is_last_in_cycle()) {
6906 print
'<a class="butActionRefused classfortooltip" href="#" title="'.$langs->trans(
"DisabledBecauseNotLastInCycle").
'">'.$langs->trans(
'CreateNextSituationInvoice').
'</a>';
6908 print
'<a class="butActionRefused classfortooltip" href="#" title="'.$langs->trans(
"DisabledBecauseFinal").
'">'.$langs->trans(
'CreateNextSituationInvoice').
'</a>';
6914 if (!$objectidnext) {
6915 print
'<!-- button create credit note -->';
6916 if (
$object->module_source ==
'takepos') {
6917 print
'<a class="butActionRefused classfortooltip" href="#" title="'.$langs->trans(
"DisabledBecauseInvoiceGeneratedBy", $langs->transnoentitiesnoconv(
'TakePOS')).
'">'.$langs->trans(
"CreateCreditNote").
'</a>';
6919 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>';
6926 &&
$object->isSituationInvoice()
6927 && (
$object->total_ttc - $totalpaid - $totalcreditnotes - $totaldeposits) > 0
6930 &&
$object->is_last_in_cycle()
6933 if ($usercanunvalidate) {
6934 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>';
6936 print
'<span class="butActionRefused classfortooltip" title="'.$langs->trans(
"NotEnoughPermissions").
'">'.$langs->trans(
"CreateCreditNote").
'</span>';
6942 if (!$objectidnext && count(
$object->lines) > 0) {
6943 unset($params[
'attr'][
'title']);
6944 print dolGetButtonAction($langs->trans(
'ChangeIntoRepeatableInvoice'),
'',
'default', DOL_URL_ROOT.
'/compta/facture/card-rec.php?facid='.
$object->id.
'&action=create',
'',
true, $params);
6950 unset($params[
'attr'][
'title']);
6951 print dolGetButtonAction($langs->trans(
'ToClone'),
'',
'clone', $_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=clone&object=invoice&token='.newToken(),
'',
true, $params);
6956 &&
$object->isSituationInvoice()
6959 &&
$object->situation_counter > 1
6960 &&
$object->is_last_in_cycle()
6961 && $usercanunvalidate
6963 if ((
$object->total_ttc - $totalcreditnotes) == 0) {
6964 print
'<a id="butSituationOut" class="butAction" href="'.$_SERVER[
'PHP_SELF'].
'?facid='.
$object->id.
'&action=situationout">'.$langs->trans(
"RemoveSituationFromCycle").
'</a>';
6966 print
'<a id="butSituationOutRefused" class="butActionRefused classfortooltip" href="#" title="'.$langs->trans(
"DisabledBecauseNotEnouthCreditNote").
'" >'.$langs->trans(
"RemoveSituationFromCycle").
'</a>';
6971 $isErasable =
$object->is_erasable();
6974 if ($isErasable == -6) {
6975 $htmltooltip = $langs->trans(
'DisabledBecauseAlreadySentByEmail');
6976 } elseif ($isErasable == -5) {
6977 $htmltooltip = $langs->trans(
'DisabledBecauseAlreadyPrintedOnce');
6978 } elseif ($isErasable == -4) {
6979 $htmltooltip = $langs->trans(
'DisabledBecausePayments');
6980 } elseif ($isErasable == -3) {
6981 $htmltooltip = $langs->trans(
'DisabledBecauseNotLastSituationInvoice');
6982 } elseif ($isErasable == -2) {
6983 $htmltooltip = $langs->trans(
'DisabledBecauseNotLastInvoice');
6984 } elseif ($isErasable == -1) {
6985 $htmltooltip = $langs->trans(
'DisabledBecauseDispatchedInBookkeeping');
6986 } elseif ($isErasable <= 0) {
6987 $htmltooltip = $langs->trans(
'DisabledBecauseNotErasable').(empty(
$object->error) ?
': UnknownReason' :
': '.$object->error);
6988 } elseif ($objectidnext) {
6989 $htmltooltip = $langs->trans(
'DisabledBecauseReplacedInvoice');
6991 if ($usercandelete || ($usercancreate && $isErasable == 1)) {
6992 $enableDelete =
false;
6994 if ($isErasable > 0 && ! $objectidnext) {
6995 $deleteHref = $_SERVER[
"PHP_SELF"].
'?facid='.
$object->id.
'&action=delete&token='.newToken();
6996 $enableDelete =
true;
6998 unset($params[
'attr'][
'title']);
6999 print dolGetButtonAction($htmltooltip, $langs->trans(
'Delete'),
'delete', $deleteHref,
'', $enableDelete, $params);
7001 unset($params[
'attr'][
'title']);
7002 print dolGetButtonAction($htmltooltip, $langs->trans(
'Delete'),
'delete',
'#',
'',
false);
7009 if (
GETPOST(
'modelselected',
'alpha')) {
7010 $action =
'presend';
7012 if ($action !=
'prerelance' && $action !=
'presend') {
7013 print
'<div class="fichecenter"><div class="fichehalfleft">';
7014 print
'<a name="builddoc"></a>';
7019 $urlsource = $_SERVER[
'PHP_SELF'].
'?facid='.
$object->id;
7020 $genallowed = $usercanread;
7021 $delallowed = $usercancreate;
7022 $tooltipAfterComboOfModels =
'';
7024 $tooltipAfterComboOfModels = $langs->trans(
"AccordingToYourSetupTheFileWillBeConcatenated",
getDolGlobalString(
'MAIN_INFO_INVOICE_TERMSOFSALE'));
7027 print $formfile->showdocuments(
7047 'remove_file_comfirm',
7048 $tooltipAfterComboOfModels
7051 $somethingshown = $formfile->numoffiles;
7054 $tmparray = $form->showLinkToObjectBlock($object, array(), array(
'invoice'), 1);
7055 $linktoelem = $tmparray[
'linktoelem'];
7056 $htmltoenteralink = $tmparray[
'htmltoenteralink'];
7057 print $htmltoenteralink;
7059 $compatibleImportElementsList =
false;
7063 $compatibleImportElementsList = array(
'commande',
'propal',
'subscription');
7065 $somethingshown = $form->showLinkedObjectBlock($object, $linktoelem, $compatibleImportElementsList);
7069 include_once DOL_DOCUMENT_ROOT.
'/core/lib/payments.lib.php';
7070 $validpaymentmethod = getValidOnlinePaymentMethods(
'');
7071 $useonlinepayment = count($validpaymentmethod);
7074 print
'<br><!-- Link to pay -->'.
"\n";
7075 require_once DOL_DOCUMENT_ROOT.
'/core/lib/payments.lib.php';
7076 print showOnlinePaymentUrl(
'invoice',
$object->ref).
'<br>';
7079 print
'</div><div class="fichehalfright">';
7083 $morehtmlcenter =
'<div class="nowraponall">';
7084 $morehtmlcenter .= dolGetButtonTitle($langs->trans(
'FullConversation'),
'',
'fa fa-comments imgforviewmode', DOL_URL_ROOT.
'/compta/facture/messaging.php?id='.
$object->id);
7085 $morehtmlcenter .= dolGetButtonTitle($langs->trans(
'FullList'),
'',
'fa fa-bars imgforviewmode', DOL_URL_ROOT.
'/compta/facture/agenda.php?id='.
$object->id);
7086 $morehtmlcenter .=
'</div>';
7089 include_once DOL_DOCUMENT_ROOT.
'/core/class/html.formactions.class.php';
7091 $somethingshown = $formactions->showactions($object,
'invoice', $socid, 1,
'', $MAXEVENT,
'', $morehtmlcenter);
7093 print
'</div></div>';
7098 $modelmail =
'facture_send';
7099 $defaulttopic =
'SendBillRef';
7101 $trackid =
'inv'.$object->id;
7103 include DOL_DOCUMENT_ROOT.
'/core/tpl/card_presend.tpl.php';
$id
Support class for third parties, contacts, members, users or resources.
if(! $sortfield) if(! $sortorder) $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 VAT - Value-added tax (also known in French as TVA)
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.
$date_start
Variables from include:
dol_now($mode='gmt')
Return date for now.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed information (by default a local PHP server timestamp) Rep...
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
GETPOSTDATE($prefix, $hourTime='', $gm='auto', $saverestore='')
Helper function that combines values of a dolibarr DatePicker (such as Form\selectDate) for year,...
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.
info_admin($text, $infoonimgalt=0, $nodiv=0, $admin='1', $morecss='hideonsmartphone', $textfordropdown='', $picto='', $textonpictotooltip='')
Show information in HTML for admin users or standard users.
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 '.
dolBuildUrl($url, $params=[], $addtoken=false, $anchor='')
Return path of url.
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.
dol_sanitizeFileName($str, $newstr='_', $unaccent=1, $includequotes=0, $allowdash=0)
Clean a string to use it as a file name.
getTaxesFromId($vatrate, $buyer=null, $seller=null, $firstparamisid=1)
Get tax (VAT) main information from Id.
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.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
if(!function_exists( 'dol_getprefix')) dol_include_once($relpath, $classname='')
Make an include_once using default root and alternate root if it fails.
GETPOSTFLOAT($paramname, $rounding='', $option=2)
Return the value of a $_GET or $_POST supervariable, converted into float.
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.
dol_buildpath($path, $type=0, $returnemptyifnotfound=0)
Return path of url or filesystem.
dol_clone($srcobject, $native=2)
Create a clone of instance of object (new instance with same value for each properties) With native =...
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false, $decorate=0)
Output date in a string format according to outputlangs (or langs if not defined).
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='', $morecssonpicto='widthpictotitle')
Load a title with picto.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
isModEnabled($module)
Is Dolibarr module enabled.
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...
get_localtax($vatrate, $local, $thirdparty_buyer=null, $thirdparty_seller=null, $vatnpr=0)
Return localtax rate for a particular VAT rate, 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.
print $langs trans("Show") . '< td style="' . $timeColor . '" align="center"> s</td > badge status0 badge status4 badge status3 Error badge status8< td align="center">< span class="badge ' . $badge . '"></span ></td >< td align="center">< a href="#" class="button button-small" onclick="openLogModal(this)" data-req="' . dol_escape_htmltag($reqSafe) . '" data-res="' . dol_escape_htmltag($resSafe) . '" data-err="' . dol_escape_htmltag($errSafe) . '">< span class="fa fa-search-plus"></span ></a ></td ></tr >< tr >< td colspan="' . $colspan . '" class="opacitymedium"></td ></tr ></table ></div ></form > logModal none logModal none s a JSON string
buildzip.php
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
'integer', 'integer:ObjectClass:PathToClass[:AddCreateButtonOrNot[:Filter[:Sortfield]]]',...
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.