33 require
'../../main.inc.php';
34 require_once DOL_DOCUMENT_ROOT .
'/fourn/class/fournisseur.facture-rec.class.php';
35 require_once DOL_DOCUMENT_ROOT .
'/fourn/class/fournisseur.product.class.php';
36 require_once DOL_DOCUMENT_ROOT .
'/product/class/product.class.php';
37 require_once DOL_DOCUMENT_ROOT .
'/core/class/html.formother.class.php';
38 if (! empty($conf->project->enabled)) {
39 include_once DOL_DOCUMENT_ROOT .
'/projet/class/project.class.php';
41 require_once DOL_DOCUMENT_ROOT .
'/core/class/html.formprojet.class.php';
42 require_once DOL_DOCUMENT_ROOT .
'/core/class/doleditor.class.php';
43 require_once DOL_DOCUMENT_ROOT .
'/core/lib/invoice.lib.php';
44 require_once DOL_DOCUMENT_ROOT .
'/core/class/extrafields.class.php';
47 $langs->loadLangs(array(
'bills',
'companies',
'compta',
'admin',
'other',
'products',
'banks',
'suppliers'));
49 $action =
GETPOST(
'action',
'alpha');
50 $massaction =
GETPOST(
'massaction',
'alpha');
51 $show_files =
GETPOST(
'show_files',
'int');
52 $confirm =
GETPOST(
'confirm',
'alpha');
53 $cancel =
GETPOST(
'cancel',
'alpha');
54 $toselect =
GETPOST(
'toselect',
'array');
55 $contextpage =
GETPOST(
'contextpage',
'aZ') ?
GETPOST(
'contextpage',
'aZ') :
'supplierinvoicetemplatelist';
57 $limit =
GETPOST(
'limit',
'int') ?
GETPOST(
'limit',
'int') : $conf->liste_limit;
58 $sortfield =
GETPOST(
"sortfield",
'alpha');
59 $sortorder =
GETPOST(
"sortorder",
'alpha');
64 $lineid =
GETPOST(
'lineid',
'int');
65 $title =
GETPOST(
'title',
'alpha');
66 $ref_supplier =
GETPOST(
'ref_supplier',
'alpha');
67 $projectid =
GETPOST(
'projectid',
'int');
68 $year_date_when =
GETPOST(
'year_date_when');
69 $month_date_when =
GETPOST(
'month_date_when');
71 $socid = $user->socid;
73 $objecttype =
'facturefournisseur_rec';
74 if ($action ==
"create" || $action ==
"add") {
78 if (empty($page) || $page == -1) {
81 $offset = $limit * $page;
86 $sortfield =
'f.titre';
88 $pageprev = $page - 1;
89 $pagenext = $page + 1;
92 if (($id > 0 || $title) && $action !=
'create' && $action !=
'add') {
93 $ret = $object->fetch($id, $title);
100 $hookmanager->initHooks(array(
'supplierinvoicereccard',
'globalcard'));
104 $extrafields->fetch_name_optionals_label($object->table_element);
106 $search_array_options = $extrafields->getOptionalsFromPost($object->table_element,
'',
'search_');
108 $permissionnote = $user->rights->fournisseur->facture->creer || $user->rights->supplier_invoice->creer;
109 $permissiondellink = $user->rights->fournisseur->facture->creer || $user->rights->supplier_invoice->creer;;
110 $permissiontoedit = $user->rights->fournisseur->facture->creer || $user->rights->supplier_invoice->creer;;
112 $usercanread = $user->rights->fournisseur->facture->lire || $user->rights->supplier_invoice->lire;
113 $usercancreate = $user->rights->fournisseur->facture->creer || $user->rights->supplier_invoice->creer;
114 $usercandelete = $user->rights->fournisseur->facture->supprimer || $user->rights->supplier_invoice->supprimer;
115 $usercanvalidate = ((empty($conf->global->MAIN_USE_ADVANCED_PERMS) && ! empty($usercancreate)) || (! empty($conf->global->MAIN_USE_ADVANCED_PERMS) && ! empty($user->rights->fournisseur->supplier_invoice_advance->validate)));
116 $usercansend = (empty($conf->global->MAIN_USE_ADVANCED_PERMS) || $user->rights->fournisseur->supplier_invoice_advance->send);
118 $usercanproductignorepricemin = ((! empty($conf->global->MAIN_USE_ADVANCED_PERMS) && empty($user->rights->produit->ignore_price_min_advance)) || empty($conf->global->MAIN_USE_ADVANCED_PERMS));
119 $usercancreatemargin = $user->rights->margins->creer;
120 $usercanreadallmargin = $user->rights->margins->liretous;
121 $usercancreatewithdrarequest = $user->rights->prelevement->bons->creer;
127 $result =
restrictedArea($user,
'facture', $object->id, $objecttype);
133 if (
GETPOST(
'cancel',
'alpha')) {
137 if (!
GETPOST(
'confirmmassaction',
'alpha') && $massaction !=
'presend' && $massaction !=
'confirm_presend') {
141 $parameters = array(
'socid' => $socid);
142 $reshook = $hookmanager->executeHooks(
'doActions', $parameters, $object, $action);
147 if (empty($reshook)) {
148 if (
GETPOST(
'cancel',
'alpha')) {
153 include DOL_DOCUMENT_ROOT .
'/core/actions_changeselectedfields.inc.php';
156 include DOL_DOCUMENT_ROOT .
'/core/actions_setnotes.inc.php';
158 include DOL_DOCUMENT_ROOT .
'/core/actions_dellink.inc.php';
160 include DOL_DOCUMENT_ROOT .
'/core/actions_lineupdown.inc.php';
163 if ($action ==
'add') {
164 if (!
GETPOST(
'title',
'alphanohtml')) {
165 setEventMessages($langs->transnoentities(
"ErrorFieldRequired", $langs->trans(
"Title")), null,
'errors');
170 $frequency =
GETPOST(
'frequency',
'int');
171 $reyear =
GETPOST(
'reyear',
'int');
172 $remonth =
GETPOST(
'remonth',
'int');
173 $reday =
GETPOST(
'reday',
'int');
174 $rehour =
GETPOST(
'rehour',
'int');
175 $remin =
GETPOST(
'remin',
'int');
176 $nb_gen_max =
GETPOST(
'nb_gen_max',
'int');
179 if (
GETPOST(
'frequency',
'int')) {
180 if (empty($reyear) || empty($remonth) || empty($reday)) {
181 setEventMessages($langs->transnoentities(
"ErrorFieldRequired", $langs->trans(
"Date")), null,
'errors');
188 $object->titre =
GETPOST(
'title',
'alphanohtml');
189 $object->title =
GETPOST(
'title',
'alphanohtml');
190 $object->fk_project =
GETPOST(
'projectid',
'int');
191 $object->ref_supplier =
GETPOST(
'ref_supplier',
'alphanohtml');
193 $object->note_private =
GETPOST(
'note_private',
'restricthtml');
194 $object->note_public =
GETPOST(
'note_public',
'restricthtml');
195 $object->model_pdf =
GETPOST(
'modelpdf',
'alpha');
196 $object->usenewprice =
GETPOST(
'usenewprice',
'alpha');
198 $object->frequency = $frequency;
199 $object->unit_frequency =
GETPOST(
'unit_frequency',
'alpha');
200 $object->nb_gen_max = $nb_gen_max;
201 $object->auto_validate =
GETPOST(
'auto_validate',
'int');
202 $object->generate_pdf =
GETPOST(
'generate_pdf',
'int');
204 $date_next_execution =
dol_mktime($rehour, $remin, 0, $remonth, $reday, $reyear);
205 $object->date_when = $date_next_execution;
210 $oldinvoice->fetch(
GETPOST(
'facid',
'int'));
212 $object->cond_reglement_id = $oldinvoice->cond_reglement_id;
213 $object->cond_reglement_code = $oldinvoice->cond_reglement_code;
214 $object->cond_reglement_label = $oldinvoice->cond_reglement_label;
215 $object->cond_reglement_doc = $oldinvoice->cond_reglement_doc;
216 $object->mode_reglement_id = $oldinvoice->mode_reglement_id;
217 $object->mode_reglement_code = $oldinvoice->mode_reglement_code;
219 $result = $object->create($user, $oldinvoice->id);
221 $result = $oldinvoice->delete($user, 1);
236 header(
"Location: " . $_SERVER[
'PHP_SELF'] .
'?facid=' . $object->id);
250 if ($action ==
'confirm_deleteinvoice' && $confirm ==
'yes' && ($user->rights->fournisseur->facture->supprimer || $user->rights->supplier_invoice->supprimer)) {
251 $object->delete($user);
253 header(
'Location: ' . DOL_URL_ROOT .
'/fourn/facture/list-rec.php');
259 if ($action ==
'setconditions' && $usercancreate) {
260 $result = $object->setPaymentTerms(
GETPOST(
'cond_reglement_id',
'int'));
261 } elseif ($action ==
'setmode' && $usercancreate) {
263 $result = $object->setPaymentMethods(
GETPOST(
'mode_reglement_id',
'int'));
264 } elseif ($action ==
'classin' && $usercancreate) {
266 $object->setProject(
GETPOST(
'projectid',
'int'));
267 } elseif ($action ==
'setref_supplier' && $usercancreate) {
268 $result = $object->setValueFrom(
'ref_supplier', $ref_supplier,
'', null,
'text',
'', $user);
272 if ($object->error ==
'DB_ERROR_RECORD_ALREADY_EXISTS') {
273 $langs->load(
"errors");
274 setEventMessages($langs->trans(
'ErrorRefAlreadyExists', $ref_supplier), null,
'errors');
279 } elseif ($action ==
'settitle' && $usercancreate) {
280 $result = $object->setValueFrom(
'titre', $title,
'', null,
'text',
'', $user);
283 $object->titre = $title;
284 $object->title = $title;
285 $object->ref = $object->title;
288 if ($object->error ==
'DB_ERROR_RECORD_ALREADY_EXISTS') {
289 $langs->load(
"errors");
290 setEventMessages($langs->trans(
'ErrorTitreAlreadyExists', $title), null,
'errors');
295 } elseif ($action ==
'setbankaccount' && $usercancreate) {
297 $result = $object->setBankAccount(
GETPOST(
'fk_account',
'int'));
298 } elseif ($action ==
'setfrequency' && $usercancreate) {
300 $object->setFrequencyAndUnit(
GETPOST(
'frequency',
'int'),
GETPOST(
'unit_frequency',
'alpha'));
301 } elseif ($action ==
'setdate_when' && $usercancreate) {
304 if (! empty($date)) {
305 $object->setNextDate($date);
307 } elseif ($action ==
'setnb_gen_max' && $usercancreate) {
309 $object->setMaxPeriod(
GETPOST(
'nb_gen_max',
'int'));
310 } elseif ($action ==
'setauto_validate' && $usercancreate) {
312 $object->setAutoValidate(
GETPOST(
'auto_validate',
'int'));
313 } elseif ($action ==
'setgenerate_pdf' && $usercancreate) {
315 $object->setGeneratepdf(
GETPOST(
'generate_pdf',
'int'));
316 } elseif ($action ==
'setmodelpdf' && $usercancreate) {
318 $object->setModelpdf(
GETPOST(
'modelpdf',
'alpha'));
319 } elseif ($action ==
'disable' && $usercancreate) {
325 $res = $object->setValueFrom(
'suspended', 1);
336 } elseif ($action ==
'enable' && $usercancreate) {
342 $res = $object->setValueFrom(
'suspended', 0);
353 } elseif ($action ==
'setmulticurrencycode' && $usercancreate) {
355 $result = $object->setMulticurrencyCode(
GETPOST(
'multicurrency_code',
'alpha'));
356 } elseif ($action ==
'setmulticurrencyrate' && $usercancreate) {
358 $result = $object->setMulticurrencyRate(
price2num(
GETPOST(
'multicurrency_tx')),
GETPOST(
'calculation_mode',
'int'));
359 } elseif ($action ==
'setlibelle' && $usercancreate) {
362 $object->libelle =
GETPOST(
'libelle');
363 $result = $object->update($user);
371 if ($action ==
'confirm_deleteline' && $confirm ==
'yes' && $usercancreate) {
373 $object->fetch_thirdparty();
382 if ($line->delete($user) > 0) {
383 $result = $object->update_price(1);
387 $object->fetch($object->id);
396 } elseif ($action ==
'update_extras') {
400 $ret = $extrafields->setOptionalsFromPost(null, $object,
GETPOST(
'attribute',
'restricthtml'));
406 $result = $object->insertExtraFields(
'BILLREC_MODIFY');
415 if ($action ==
'addline' && $usercancreate) {
416 $langs->load(
'errors');
424 $prod_entry_mode =
GETPOST(
'prod_entry_mode',
'alpha');
425 if ($prod_entry_mode ==
'free') {
427 $tva_tx = (
GETPOST(
'tva_tx',
'alpha') ?
GETPOST(
'tva_tx',
'alpha') : 0);
428 $ref_fournisseur = (
GETPOSTISSET(
'fourn_ref') ?
GETPOST(
'fourn_ref',
'restricthtml') :
'');
430 $idprod =
GETPOST(
'idprod',
'int');
438 $extralabelsline = $extrafields->fetch_name_optionals_label($object->table_element_line);
439 $array_options = $extrafields->getOptionalsFromPost($object->table_element_line, $predef);
441 if (is_array($extralabelsline)) {
443 foreach ($extralabelsline as $key => $value) {
444 unset($_POST[
"options_" . $key . $predef]);
448 if ((empty($idprod) || $idprod < 0) && ($price_ht < 0) && ($qty < 0)) {
449 setEventMessages($langs->trans(
'ErrorBothFieldCantBeNegative', $langs->transnoentitiesnoconv(
'UnitPriceHT'), $langs->transnoentitiesnoconv(
'Qty')), null,
'errors');
452 if ($prod_entry_mode ==
'free' && (empty($idprod) || $idprod < 0) &&
GETPOST(
'type') < 0) {
453 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'Type')), null,
'errors');
456 if ($prod_entry_mode ==
'free' && (empty($idprod) || $idprod < 0) && (! ($price_ht >= 0) || $price_ht ==
'')) {
457 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"UnitPriceHT")), null,
'errors');
461 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'Qty')), null,
'errors');
464 if ($prod_entry_mode ==
'free' && (empty($idprod) || $idprod < 0) && empty($product_desc)) {
465 setEventMessages($langs->trans(
'ErrorFieldRequired', $langs->transnoentitiesnoconv(
'Description')), null,
'errors');
469 $langs->load(
"errors");
470 setEventMessages($langs->trans(
'ErrorQtyForCustomerInvoiceCantBeNegative'), null,
'errors');
474 if ($prod_entry_mode !=
'free' && empty($error)) {
478 if (
GETPOST(
'idprodfournprice',
'alpha') == -1 ||
GETPOST(
'idprodfournprice',
'alpha') ==
'') {
482 if (preg_match(
'/^idprod_([0-9]+)$/',
GETPOST(
'idprodfournprice',
'alpha'), $reg)) {
483 $idprod = (int) $reg[1];
484 $res = $productsupplier->fetch($idprod);
487 if (! empty($conf->global->SUPPLIER_TAKE_FIRST_PRICE_IF_NO_PRICE_FOR_CURRENT_SUPPLIER)) {
489 $productsupplier->get_buyprice(0, -1, $idprod,
'none', $fksoctosearch);
490 if ($productsupplier->fourn_socid != $socid) {
491 $productsupplier->ref_supplier =
'';
494 $fksoctosearch = $object->thirdparty->id;
495 $productsupplier->get_buyprice(0, -1, $idprod,
'none', $fksoctosearch);
497 } elseif (
GETPOST(
'idprodfournprice',
'alpha') > 0) {
499 $idprod = $productsupplier->get_buyprice(
GETPOST(
'idprodfournprice',
'alpha'), $qtytosearch);
500 $res = $productsupplier->fetch($idprod);
501 $ref_fournisseur = $productsupplier->ref_supplier;
505 if (! $error && ($qty >= 0) && (! empty($product_desc) || (! empty($idprod) && $idprod > 0))) {
506 $ret = $object->fetch($id);
511 $ret = $object->fetch_thirdparty();
514 $date_start =
dol_mktime(
GETPOST(
'date_start' . $predef .
'hour'),
GETPOST(
'date_start' . $predef .
'min'),
GETPOST(
'date_start' . $predef .
'sec'),
GETPOST(
'date_start' . $predef .
'month'),
GETPOST(
'date_start' . $predef .
'day'),
GETPOST(
'date_start' . $predef .
'year'));
515 $date_end =
dol_mktime(
GETPOST(
'date_end' . $predef .
'hour'),
GETPOST(
'date_end' . $predef .
'min'),
GETPOST(
'date_end' . $predef .
'sec'),
GETPOST(
'date_end' . $predef .
'month'),
GETPOST(
'date_end' . $predef .
'day'),
GETPOST(
'date_end' . $predef .
'year'));
516 $price_base_type = (
GETPOST(
'price_base_type',
'alpha') ?
GETPOST(
'price_base_type',
'alpha') :
'HT');
527 if (! empty($idprod) && $idprod > 0) {
529 $prod->fetch($idprod);
531 $label = ((
GETPOST(
'product_label') &&
GETPOST(
'product_label') != $prod->label) ?
GETPOST(
'product_label') :
'');
536 if (empty($tva_tx)) {
543 $datapriceofproduct = $prod->getSellPrice($mysoc, $object->thirdparty, $pqp);
545 $pu_ht = $datapriceofproduct[
'pu_ht'];
546 $pu_ttc = $datapriceofproduct[
'pu_ttc'];
547 $price_min = $datapriceofproduct[
'price_min'];
548 $price_base_type = $datapriceofproduct[
'price_base_type'];
549 $tva_tx = $datapriceofproduct[
'tva_tx'];
550 $tva_npr = $datapriceofproduct[
'tva_npr'];
552 $tmpvat =
price2num(preg_replace(
'/\s*\(.*\)/',
'', $tva_tx));
553 $tmpprodvat =
price2num(preg_replace(
'/\s*\(.*\)/',
'', $prod->tva_tx));
556 if (! empty($price_ht)) {
558 $pu_ttc =
price2num($pu_ht * (1 + ($tmpvat / 100)),
'MU');
559 } elseif ($tmpvat != $tmpprodvat) {
562 if ($price_base_type !=
'HT') {
563 $pu_ht =
price2num($pu_ttc / (1 + ($tmpvat / 100)),
'MU');
565 $pu_ttc =
price2num($pu_ht * (1 + ($tmpvat / 100)),
'MU');
572 if (! empty($conf->global->MAIN_MULTILANGS) && ! empty($conf->global->PRODUIT_TEXTS_IN_THIRDPARTY_LANGUAGE)) {
573 $outputlangs = $langs;
575 if (empty($newlang) &&
GETPOST(
'lang_id',
'aZ09')) {
576 $newlang =
GETPOST(
'lang_id',
'aZ09');
578 if (empty($newlang)) {
579 $newlang = $object->thirdparty->default_lang;
581 if (! empty($newlang)) {
583 $outputlangs->setDefaultLang($newlang);
586 $desc = (! empty($prod->multilangs [$outputlangs->defaultlang] [
"description"])) ? $prod->multilangs [$outputlangs->defaultlang] [
"description"] : $prod->description;
588 $desc = $prod->description;
594 if (empty($conf->global->MAIN_PRODUCT_DISABLE_CUSTOMCOUNTRYCODE) && (! empty($prod->customcode) || ! empty($prod->country_code))) {
597 if (! empty($conf->global->MAIN_MULTILANGS) && ! empty($conf->global->PRODUIT_TEXTS_IN_THIRDPARTY_LANGUAGE)) {
598 $outputlangs = $langs;
600 if (empty($newlang) &&
GETPOST(
'lang_id',
'alpha')) {
601 $newlang =
GETPOST(
'lang_id',
'alpha');
603 if (empty($newlang)) {
604 $newlang = $object->thirdparty->default_lang;
606 if (! empty($newlang)) {
608 $outputlangs->setDefaultLang($newlang);
609 $outputlangs->load(
'products');
611 if (! empty($prod->customcode)) {
612 $tmptxt .= $outputlangs->transnoentitiesnoconv(
"CustomCode") .
': ' . $prod->customcode;
614 if (! empty($prod->customcode) && ! empty($prod->country_code)) {
617 if (! empty($prod->country_code)) {
618 $tmptxt .= $outputlangs->transnoentitiesnoconv(
"CountryOrigin") .
': ' .
getCountry($prod->country_code, 0, $db, $outputlangs, 0);
621 if (! empty($prod->customcode)) {
622 $tmptxt .= $langs->transnoentitiesnoconv(
"CustomCode") .
': ' . $prod->customcode;
624 if (! empty($prod->customcode) && ! empty($prod->country_code)) {
627 if (! empty($prod->country_code)) {
628 $tmptxt .= $langs->transnoentitiesnoconv(
"CountryOrigin") .
': ' .
getCountry($prod->country_code, 0, $db, $langs, 0);
636 $fk_unit = $prod->fk_unit;
640 $tva_npr = (preg_match(
'/\*/', $tva_tx) ? 1 : 0);
641 $tva_tx = str_replace(
'*',
'', $tva_tx);
642 if (empty($tva_tx)) {
645 $desc = $product_desc;
647 $fk_unit =
GETPOST(
'units',
'alpha');
650 $date_start_fill = ! empty(
GETPOST(
'date_start_fill',
'int')) ?
GETPOST(
'date_start_fill',
'int') : null;
651 $date_end_fill = ! empty(
GETPOST(
'date_end_fill',
'int')) ?
GETPOST(
'date_end_fill',
'int') : null;
658 $localtax1_tx =
get_localtax($tva_tx, 1, $object->thirdparty, $mysoc, $tva_npr);
659 $localtax2_tx =
get_localtax($tva_tx, 2, $object->thirdparty, $mysoc, $tva_npr);
670 if ($usercanproductignorepricemin && (! empty($price_min) && ($pu_ht * (1 - $remise_percent / 100) < $price_min))) {
671 $mesg = $langs->trans(
"CantBeLessThanMinPrice",
price(
price2num($price_min,
'MU'), 0, $langs, 0, 0, -1, $conf->currency));
675 $result = $object->addline($idprod, $ref_fournisseur, $label, $desc, $pu_ht, $pu_ttc, $qty, $remise_percent, $tva_tx, $localtax1_tx, $localtax2_tx, $price_base_type, $type, $date_start_fill, $date_end_fill, $info_bits, $special_code, -1, $fk_unit);
678 $object->fetch($object->id);
680 unset($_POST[
'prod_entry_mode']);
681 unset($_POST[
'qty']);
682 unset($_POST[
'type']);
683 unset($_POST[
'remise_percent']);
684 unset($_POST[
'price_ht']);
685 unset($_POST[
'multicurrency_price_ht']);
686 unset($_POST[
'price_ttc']);
687 unset($_POST[
'tva_tx']);
688 unset($_POST[
'product_ref']);
689 unset($_POST[
'product_label']);
690 unset($_POST[
'product_desc']);
691 unset($_POST[
'fournprice']);
692 unset($_POST[
'buying_price']);
693 unset($_POST[
'np_marginRate']);
694 unset($_POST[
'np_markRate']);
695 unset($_POST[
'dp_desc']);
696 unset($_POST[
'idprod']);
697 unset($_POST[
'units']);
698 unset($_POST[
'date_starthour']);
699 unset($_POST[
'date_startmin']);
700 unset($_POST[
'date_startsec']);
701 unset($_POST[
'date_startday']);
702 unset($_POST[
'date_startmonth']);
703 unset($_POST[
'date_startyear']);
704 unset($_POST[
'date_endhour']);
705 unset($_POST[
'date_endmin']);
706 unset($_POST[
'date_endsec']);
707 unset($_POST[
'date_endday']);
708 unset($_POST[
'date_endmonth']);
709 unset($_POST[
'date_endyear']);
710 unset($_POST[
'date_start_fill']);
711 unset($_POST[
'date_end_fill']);
712 unset($_POST[
'situations']);
713 unset($_POST[
'progress']);
721 } elseif ($action ==
'updateline' && $usercancreate && !
GETPOST(
'cancel',
'alpha')) {
722 if (! $object->fetch($id) > 0) {
725 $object->fetch_thirdparty();
731 $ref_fourn =
GETPOST(
'fourn_ref',
'alpha');
739 if (preg_match(
'/\*/', $vat_rate)) {
744 $vat_rate = str_replace(
'*',
'', $vat_rate);
745 $localtax1_rate =
get_localtax($vat_rate, 1, $object->thirdparty);
746 $localtax2_rate =
get_localtax($vat_rate, 2, $object->thirdparty);
749 $extralabelsline = $extrafields->fetch_name_optionals_label($object->table_element_line);
750 $array_options = $extrafields->getOptionalsFromPost($object->table_element_line);
753 if ($objectline->fetch(
GETPOST(
'lineid',
'int'))) {
754 $objectline->array_options = $array_options;
755 $result = $objectline->insertExtraFields();
761 $position = ($objectline->rang >= 0 ? $objectline->rang : 0);
764 if (is_array($extralabelsline)) {
766 foreach ($extralabelsline as $key => $value) {
767 unset($_POST[
"options_" . $key]);
772 $special_code =
GETPOST(
'special_code',
'int');
773 if (!
GETPOST(
'qty',
'alpha')) {
780 $productid =
GETPOST(
'productid',
'int');
781 if (! empty($productid)) {
783 $product->fetch($productid);
785 $type = $product->type;
787 $price_min = $product->price_min;
788 if (! empty($conf->global->PRODUIT_MULTIPRICES) && ! empty($object->thirdparty->price_level)) {
789 $price_min = $product->multiprices_min[$object->thirdparty->price_level];
792 $label = $product->label;
795 if (((! empty($conf->global->MAIN_USE_ADVANCED_PERMS) && empty($user->rights->produit->ignore_price_min_advance)) || empty($conf->global->MAIN_USE_ADVANCED_PERMS)) && $price_min && (
price2num($pu_ht) * (1 - $remise_percent / 100) <
price2num($price_min))) {
796 setEventMessages($langs->trans(
"CantBeLessThanMinPrice",
price(
price2num($price_min,
'MU'), 0, $langs, 0, 0, -1, $conf->currency)), null,
'errors');
800 $type =
GETPOST(
'type',
'int');
801 $label = (
GETPOST(
'product_label') ?
GETPOST(
'product_label') :
'');
804 if (
GETPOST(
'type',
'int') < 0) {
805 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Type")), null,
'errors');
810 $langs->load(
"errors");
811 setEventMessages($langs->trans(
'ErrorQtyForCustomerInvoiceCantBeNegative'), null,
'errors');
815 $date_start_fill = ! empty(
GETPOST(
'date_start_fill',
'int')) ?
GETPOST(
'date_start_fill',
'int') :
'NULL';
816 $date_end_fill = ! empty(
GETPOST(
'date_end_fill',
'int')) ?
GETPOST(
'date_end_fill',
'int') :
'NULL';
820 $result = $object->updateline(
GETPOST(
'lineid',
'int'),
GETPOST(
'productid',
'int'), $ref_fourn, $label, $description, $pu_ht, $qty, $remise_percent, $vat_rate, $localtax1_rate, $localtax1_rate,
'HT', $type, $date_start_fill, $date_end_fill, $info_bits, $special_code, -1);
822 $object->fetch($object->id);
824 unset($_POST[
'qty']);
825 unset($_POST[
'type']);
826 unset($_POST[
'productid']);
827 unset($_POST[
'remise_percent']);
828 unset($_POST[
'price_ht']);
829 unset($_POST[
'multicurrency_price_ht']);
830 unset($_POST[
'price_ttc']);
831 unset($_POST[
'tva_tx']);
832 unset($_POST[
'product_ref']);
833 unset($_POST[
'product_label']);
834 unset($_POST[
'product_desc']);
835 unset($_POST[
'fournprice']);
836 unset($_POST[
'buying_price']);
837 unset($_POST[
'np_marginRate']);
838 unset($_POST[
'np_markRate']);
839 unset($_POST[
'dp_desc']);
840 unset($_POST[
'idprod']);
841 unset($_POST[
'units']);
842 unset($_POST[
'date_starthour']);
843 unset($_POST[
'date_startmin']);
844 unset($_POST[
'date_startsec']);
845 unset($_POST[
'date_startday']);
846 unset($_POST[
'date_startmonth']);
847 unset($_POST[
'date_startyear']);
848 unset($_POST[
'date_endhour']);
849 unset($_POST[
'date_endmin']);
850 unset($_POST[
'date_endsec']);
851 unset($_POST[
'date_endday']);
852 unset($_POST[
'date_endmonth']);
853 unset($_POST[
'date_endyear']);
854 unset($_POST[
'situations']);
855 unset($_POST[
'progress']);
872 if (! empty($conf->project->enabled)) {
875 $companystatic =
new Societe($db);
884 if ($action ==
'create') {
885 print
load_fiche_titre($langs->trans(
"CreateRepeatableInvoice"),
'',
'bill');
888 $product_static =
new Product($db);
890 if ($object->fetch($id) > 0) {
891 $result = $object->fetch_lines();
893 print
'<form action="' . $_SERVER[
"PHP_SELF"] .
'" method="POST">';
894 print
'<input type="hidden" name="token" value="' .
newToken() .
'">';
895 print
'<input type="hidden" name="action" value="add">';
896 print
'<input type="hidden" name="facid" value="' . $object->id .
'">';
901 if (! empty($conf->project->enabled)) $rowspan++;
902 if ($object->fk_account > 0) $rowspan++;
904 print
'<table class="border centpercent">';
906 $object->fetch_thirdparty();
909 print
'<tr><td class="titlefieldcreate fieldrequired">' . $langs->trans(
"Title") .
'</td><td>';
910 print
'<input class="flat quatrevingtpercent" type="text" name="title" value="' .
dol_escape_htmltag(
GETPOST(
"title",
'alphanohtml')) .
'">';
914 print
'<tr><td class="titlefieldcreate fieldrequired">' . $langs->trans(
"SupplierRef") .
'</td><td>';
915 print
'<input class="flat quatrevingtpercent" type="text" name="ref_supplier" value="' . $object->ref_supplier .
'">';
919 print
'<tr><td class="titlefieldcreate">' . $langs->trans(
"Customer") .
'</td><td>' . $object->thirdparty->getNomUrl(1,
'customer') .
'</td>';
922 $note_public =
GETPOSTISSET(
'note_public') ?
GETPOST(
'note_public',
'restricthtml') : $object->note_public;
923 $note_private =
GETPOSTISSET(
'note_private') ?
GETPOST(
'note_private',
'restricthtml') : $object->note_private;
928 $substitutionarray[
'__INVOICE_PREVIOUS_MONTH__'] = $langs->trans(
"PreviousMonthOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($object->date, -1,
'm'),
'%m') .
')';
929 $substitutionarray[
'__INVOICE_MONTH__'] = $langs->trans(
"MonthOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date($object->date,
'%m') .
')';
930 $substitutionarray[
'__INVOICE_NEXT_MONTH__'] = $langs->trans(
"NextMonthOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($object->date, 1,
'm'),
'%m') .
')';
931 $substitutionarray[
'__INVOICE_PREVIOUS_MONTH_TEXT__'] = $langs->trans(
"TextPreviousMonthOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($object->date, -1,
'm'),
'%B') .
')';
932 $substitutionarray[
'__INVOICE_MONTH_TEXT__'] = $langs->trans(
"TextMonthOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date($object->date,
'%B') .
')';
933 $substitutionarray[
'__INVOICE_NEXT_MONTH_TEXT__'] = $langs->trans(
"TextNextMonthOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($object->date, 1,
'm'),
'%B') .
')';
934 $substitutionarray[
'__INVOICE_PREVIOUS_YEAR__'] = $langs->trans(
"PreviousYearOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($object->date, -1,
'y'),
'%Y') .
')';
935 $substitutionarray[
'__INVOICE_YEAR__'] = $langs->trans(
"YearOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date($object->date,
'%Y') .
')';
936 $substitutionarray[
'__INVOICE_NEXT_YEAR__'] = $langs->trans(
"NextYearOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($object->date, 1,
'y'),
'%Y') .
')';
938 $substitutionarray[
'__INVOICE_DATE_NEXT_INVOICE_BEFORE_GEN__'] = $langs->trans(
"DateNextInvoiceBeforeGen") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date($object->date_when,
'dayhour') .
')';
939 $substitutionarray[
'__INVOICE_DATE_NEXT_INVOICE_AFTER_GEN__'] = $langs->trans(
"DateNextInvoiceAfterGen") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($object->date_when, $object->frequency, $object->unit_frequency),
'dayhour') .
')';
940 $substitutionarray[
'__INVOICE_COUNTER_CURRENT__'] = $langs->trans(
"Count");
941 $substitutionarray[
'__INVOICE_COUNTER_MAX__'] = $langs->trans(
"MaxPeriodNumber");
943 $htmltext =
'<i>' . $langs->trans(
"FollowingConstantsWillBeSubstituted") .
':<br>';
944 foreach ($substitutionarray as $key => $val) {
945 $htmltext .= $key .
' = ' . $langs->trans($val) .
'<br>';
950 print
'<tr><td class="titlefieldcreate">' . $langs->trans(
"Label") .
'</td><td>';
951 print
'<input class="flat quatrevingtpercent" type="text" name="libelle" value="' . $object->label .
'">';
956 print
'<td class="tdtop">';
957 print $form->textwithpicto($langs->trans(
'NotePublic'), $htmltext, 1,
'help',
'', 0, 2,
'notepublic');
960 $doleditor =
new DolEditor(
'note_public', $note_public,
'', 80,
'dolibarr_notes',
'In', 0,
false, empty($conf->global->FCKEDITOR_ENABLE_NOTE_PUBLIC) ? 0 : 1, ROWS_3,
'90%');
961 print $doleditor->Create(1);
964 if (empty($user->socid)) {
966 print
'<td class="tdtop">';
967 print $form->textwithpicto($langs->trans(
'NotePrivate'), $htmltext, 1,
'help',
'', 0, 2,
'noteprivate');
970 $doleditor =
new DolEditor(
'note_private', $note_private,
'', 80,
'dolibarr_notes',
'In', 0,
false, empty($conf->global->FCKEDITOR_ENABLE_NOTE_PRIVATE) ? 0 : 1, ROWS_3,
'90%');
971 print $doleditor->Create(1);
976 print
"<tr><td>" . $langs->trans(
"Author") .
"</td><td>" . $user->getFullName($langs) .
"</td></tr>";
979 print
"<tr><td>" . $langs->trans(
"PaymentConditions") .
"</td><td>";
980 $form->form_conditions_reglement($_SERVER[
'PHP_SELF'] .
'?id=' . $object->id, $object->cond_reglement_id,
'none');
984 print
"<tr><td>" . $langs->trans(
"PaymentMode") .
"</td><td>";
985 $form->form_modes_reglement($_SERVER[
'PHP_SELF'] .
'?id=' . $object->id, $object->mode_reglement_id,
'none',
'', 1);
989 if (! empty($conf->project->enabled) && is_object($object->thirdparty) && $object->thirdparty->id > 0) {
990 $projectid =
GETPOST(
'projectid') ?
GETPOST(
'projectid') : $object->fk_project;
991 $langs->load(
'projects');
992 print
'<tr><td>' . $langs->trans(
'Project') .
'</td><td>';
993 $numprojet = $formproject->select_projects($object->thirdparty->id, $projectid,
'projectid', 0, 0, 1, 0, 0, 0, 0,
'', 0, 0,
'');
994 print
' <a href="' . DOL_URL_ROOT .
'/projet/card.php?socid=' . $object->thirdparty->id .
'&action=create&status=1&backtopage=' . urlencode($_SERVER[
"PHP_SELF"] .
'?action=create&socid=' . $object->thirdparty->id . (! empty($id) ?
'&id=' . $id :
'')) .
'">' . $langs->trans(
"AddProject") .
'</a>';
999 if ($object->fk_account > 0) {
1000 print
"<tr><td>" . $langs->trans(
'BankAccount') .
"</td><td>";
1001 $form->formSelectAccount($_SERVER[
'PHP_SELF'] .
'?id=' . $object->id, $object->fk_account,
'none');
1006 print
"<tr><td>" . $langs->trans(
'Model') .
"</td><td>";
1007 include_once DOL_DOCUMENT_ROOT .
'/core/modules/supplier_invoice/modules_facturefournisseur.php';
1009 print $form->selectarray(
'modelpdf', $list, $conf->global->INVOICE_SUPPLIER_ADDON_PDF);
1017 $title = $langs->trans(
"Recurrence");
1022 print
'<table class="border centpercent">';
1025 print
'<tr><td class="titlefieldcreate">' . $form->textwithpicto($langs->trans(
"Frequency"), $langs->transnoentitiesnoconv(
'toolTipFrequency')) .
"</td><td>";
1026 print
"<input type='text' name='frequency' value='" .
GETPOST(
'frequency',
'int') .
"' size='4' /> " . $form->selectarray(
'unit_frequency', array(
'd' => $langs->trans(
'Day'),
'm' => $langs->trans(
'Month'),
'y' => $langs->trans(
'Year')), (
GETPOST(
'unit_frequency') ?
GETPOST(
'unit_frequency') :
'm'));
1030 print
"<tr><td>" . $langs->trans(
'NextDateToExecution') .
"</td><td>";
1032 print $form->selectDate($date_next_execution,
'', 1, 1,
'',
"add", 1, 1);
1036 print
"<tr><td>" . $langs->trans(
"MaxPeriodNumber") .
"</td><td>";
1037 print
'<input type="text" name="nb_gen_max" value="' .
GETPOST(
'nb_gen_max') .
'" size="5" />';
1041 print
"<tr><td>" . $langs->trans(
"StatusOfGeneratedInvoices") .
"</td><td>";
1042 $select = array(
'0' => $langs->trans(
'BillStatusDraft'),
'1' => $langs->trans(
'BillStatusValidated'));
1043 print $form->selectarray(
'auto_validate', $select,
GETPOST(
'auto_validate'));
1047 if (! empty($conf->global->INVOICE_REC_CAN_DISABLE_DOCUMENT_FILE_GENERATION)) {
1048 print
"<tr><td>" . $langs->trans(
"StatusOfGeneratedDocuments") .
"</td><td>";
1049 $select = array(
'0' => $langs->trans(
'DoNotGenerateDoc'),
'1' => $langs->trans(
'AutoGenerateDoc'));
1050 print $form->selectarray(
'generate_pdf', $select,
GETPOST(
'generate_pdf'));
1053 print
'<input type="hidden" name="generate_pdf" value="1">';
1060 $title = $langs->trans(
"ProductsAndServices");
1061 if (empty($conf->service->enabled)) {
1062 $title = $langs->trans(
"Products");
1063 } elseif (empty($conf->product->enabled)) {
1064 $title = $langs->trans(
"Services");
1072 print
'<div class="div-table-responsive-no-min">';
1073 print
'<table id="tablelines" class="noborder noshadow" width="100%">';
1075 if (! empty($object->lines)) {
1079 $object->printObjectLines(
'', $mysoc, $object->thirdparty, $lineid, 0);
1087 print $form->buttonsSaveCancel(
"Create");
1097 if ($object->id > 0) {
1098 $object->fetch($object->id);
1099 $object->fetch_thirdparty();
1102 if ($action ==
'ask_deleteline') {
1103 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"] .
'?id=' . $object->id .
'&lineid=' . $lineid, $langs->trans(
'DeleteProductLine'), $langs->trans(
'ConfirmDeleteProductLine'),
'confirm_deleteline',
'',
'no', 1);
1107 if ($action ==
'ask_deleteinvoice') {
1108 $formconfirm = $form->formconfirm($_SERVER[
"PHP_SELF"] .
'?id=' . $object->id, $langs->trans(
'DeleteRepeatableInvoice'), $langs->trans(
'ConfirmDeleteRepeatableInvoice'),
'confirm_deleteinvoice',
'',
'no', 1);
1113 $author =
new User($db);
1114 $author->fetch($object->user_author);
1118 print
dol_get_fiche_head($head,
'card', $langs->trans(
'RepeatableInvoice'), -1,
'bill');
1122 $linkback =
'<a href="' . DOL_URL_ROOT .
'/fourn/facture/list-rec.php?restore_lastsearch_values=1' . (! empty($socid) ?
'&socid=' . $socid :
'') .
'">' . $langs->trans(
'BackToList') .
'</a>';
1125 if ($action !=
'edittitle') {
1126 $morehtmlref .= $form->editfieldkey($object->titre,
'title', $object->titre, $object, $usercancreate,
'',
'', 0, 2);
1128 $morehtmlref .= $form->editfieldval(
'',
'title', $object->titre, $object, $usercancreate,
'string');
1130 $morehtmlref .=
'<div class="refidno">';
1132 $morehtmlref .= $form->editfieldkey(
"RefSupplier",
'ref_supplier', $object->ref_supplier, $object, $usercancreate,
'string',
'', 0, 1);
1133 $morehtmlref .= $form->editfieldval(
"RefSupplier",
'ref_supplier', $object->ref_supplier, $object, $usercancreate,
'string',
'', null, null,
'', 1);
1135 $morehtmlref .=
'<br>' . $langs->trans(
'ThirdParty') .
' : ' . $object->thirdparty->getNomUrl(1);
1138 if (! empty($conf->project->enabled)) {
1139 $langs->load(
'projects');
1140 $morehtmlref .=
'<br>' . $langs->trans(
'Project') .
' ';
1141 if ($usercancreate) {
1142 if ($action !=
'classify') {
1143 $morehtmlref .=
'<a class="editfielda" href="' . $_SERVER[
'PHP_SELF'] .
'?action=classify&token=' .
newToken() .
'&id=' . $object->id .
'">' .
img_edit($langs->transnoentitiesnoconv(
'SetProject')) .
'</a> : ';
1145 if ($action ==
'classify') {
1146 $morehtmlref .=
'<form method="post" action="' . $_SERVER[
'PHP_SELF'] .
'?id=' . $object->id .
'">';
1147 $morehtmlref .=
'<input type="hidden" name="action" value="classin">';
1148 $morehtmlref .=
'<input type="hidden" name="token" value="' .
newToken() .
'">';
1149 $morehtmlref .= $formproject->select_projects($object->socid, $object->fk_project,
'projectid', $maxlength, 0, 1, 0, 1, 0, 0,
'', 1);
1150 $morehtmlref .=
'<input type="submit" class="button valignmiddle" value="' . $langs->trans(
"Modify") .
'">';
1151 $morehtmlref .=
'</form>';
1153 $morehtmlref .= $form->form_project($_SERVER[
'PHP_SELF'] .
'?id=' . $object->id, $object->socid, $object->fk_project,
'none', 0, 0, 0, 1);
1156 if (! empty($object->fk_project)) {
1158 $project->fetch($object->fk_project);
1159 $morehtmlref .=
' : ' . $project->getNomUrl(1);
1160 if ($project->title) {
1161 $morehtmlref .=
' - ' . $project->title;
1168 $morehtmlref .=
'</div>';
1170 $morehtmlright =
'';
1172 dol_banner_tab($object,
'ref', $linkback, 1,
'title',
'none', $morehtmlref,
'', 0,
'', $morehtmlright);
1174 print
'<div class="fichecenter">';
1175 print
'<div class="fichehalfleft">';
1176 print
'<div class="underbanner clearboth"></div>';
1178 print
'<table class="border centpercent tableforfield">';
1180 print
'<tr><td class="titlefield">' . $langs->trans(
'Author') .
'</td><td>';
1181 print $author->getNomUrl(-1);
1186 print
'<td>' . $form->editfieldkey(
"Label",
'libelle', $object->libelle, $object, $usercancreate) .
'</td>';
1187 print
'<td>' . $form->editfieldval(
"Label",
'libelle', $object->libelle, $object, $usercancreate) .
'</td>';
1190 print
'<tr><td>' . $langs->trans(
'AmountHT') .
'</td>';
1191 print
'<td>' .
price($object->total_ht,
'', $langs, 1, -1, -1, $conf->currency) .
'</td>';
1194 print
'<tr><td>' . $langs->trans(
"AmountVAT") .
'</td><td>' .
price($object->total_tva,
'', $langs, 1, -1, -1, $conf->currency) .
'</td>';
1198 if (($mysoc->localtax1_assuj ==
"1" && $mysoc->useLocalTax(1)) || $object->total_localtax1 != 0) {
1199 print
'<tr><td>' . $langs->transcountry(
"AmountLT1", $mysoc->country_code) .
'</td>';
1200 print
'<td class="nowrap">' .
price($object->total_localtax1, 1,
'', 1, -1, -1, $conf->currency) .
'</td></tr>';
1202 if (($mysoc->localtax2_assuj ==
"1" && $mysoc->useLocalTax(2)) || $object->total_localtax2 != 0) {
1203 print
'<tr><td>' . $langs->transcountry(
"AmountLT2", $mysoc->country_code) .
'</td>';
1204 print
'<td class=nowrap">' .
price($object->total_localtax2, 1,
'', 1, -1, -1, $conf->currency) .
'</td></tr>';
1207 print
'<tr><td>' . $langs->trans(
"AmountTTC") .
'</td><td colspan="3">' .
price($object->total_ttc,
'', $langs, 1, -1, -1, $conf->currency) .
'</td>';
1212 print
'<table class="nobordernopadding centpercent"><tr><td>';
1213 print $langs->trans(
'PaymentConditionsShort');
1215 if ($action !=
'editconditions' && $usercancreate) {
1216 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>';
1218 print
'</tr></table>';
1220 if ($action ==
'editconditions') {
1221 $form->form_conditions_reglement($_SERVER[
'PHP_SELF'] .
'?facid=' . $object->id, $object->cond_reglement_id,
'cond_reglement_id');
1223 $form->form_conditions_reglement($_SERVER[
'PHP_SELF'] .
'?facid=' . $object->id, $object->cond_reglement_id,
'none');
1230 print
'<table class="nobordernopadding" width="100%"><tr><td>';
1231 print $langs->trans(
'PaymentMode');
1233 if ($action !=
'editmode' && $usercancreate) {
1234 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>';
1236 print
'</tr></table>';
1238 if ($action ==
'editmode') {
1239 $form->form_modes_reglement($_SERVER[
'PHP_SELF'] .
'?facid=' . $object->id, $object->mode_reglement_id,
'mode_reglement_id',
'CRDT', 1, 1);
1241 $form->form_modes_reglement($_SERVER[
'PHP_SELF'] .
'?facid=' . $object->id, $object->mode_reglement_id,
'none');
1246 if (! empty($conf->multicurrency->enabled)) {
1250 print
'<table class="nobordernopadding" width="100%"><tr><td>';
1251 print $form->editfieldkey(
'Currency',
'multicurrency_code',
'', $object, 0);
1253 if ($usercancreate && $action !=
'editmulticurrencycode' && ! empty($object->brouillon)) {
1254 print
'<td class="right"><a class="editfielda" href="' . $_SERVER[
"PHP_SELF"] .
'?action=editmulticurrencycode&token=' .
newToken() .
'&id=' . $object->id .
'">' .
img_edit($langs->transnoentitiesnoconv(
'SetMultiCurrencyCode'), 1) .
'</a></td>';
1256 print
'</tr></table>';
1258 $htmlname = (($usercancreate && $action ==
'editmulticurrencycode') ?
'multicurrency_code' :
'none');
1259 $form->form_multicurrency_code($_SERVER[
'PHP_SELF'] .
'?id=' . $object->id, $object->multicurrency_code, $htmlname);
1263 if ($object->multicurrency_code != $conf->currency || $object->multicurrency_tx != 1) {
1266 print
'<table class="nobordernopadding" width="100%"><tr><td>';
1267 print $form->editfieldkey(
'CurrencyRate',
'multicurrency_tx',
'', $object, 0);
1269 if ($usercancreate && $action !=
'editmulticurrencyrate' && ! empty($object->brouillon) && $object->multicurrency_code && $object->multicurrency_code != $conf->currency) {
1270 print
'<td class="right"><a class="editfielda" href="' . $_SERVER[
"PHP_SELF"] .
'?action=editmulticurrencyrate&token=' .
newToken() .
'&id=' . $object->id .
'">' .
img_edit($langs->transnoentitiesnoconv(
'SetMultiCurrencyCode'), 1) .
'</a></td>';
1272 print
'</tr></table>';
1274 if ($action ==
'editmulticurrencyrate' || $action ==
'actualizemulticurrencyrate') {
1275 if ($action ==
'actualizemulticurrencyrate') {
1278 $form->form_multicurrency_rate($_SERVER[
'PHP_SELF'] .
'?id=' . $object->id, $object->multicurrency_tx, ($usercancreate ?
'multicurrency_tx' :
'none'), $object->multicurrency_code);
1280 $form->form_multicurrency_rate($_SERVER[
'PHP_SELF'] .
'?id=' . $object->id, $object->multicurrency_tx,
'none', $object->multicurrency_code);
1281 if ($object->statut == $object::STATUS_DRAFT && $object->multicurrency_code && $object->multicurrency_code != $conf->currency) {
1282 print
'<div class="inline-block"> ';
1283 print
'<a href="' . $_SERVER[
"PHP_SELF"] .
'?id=' . $object->id .
'&action=actualizemulticurrencyrate">' . $langs->trans(
"ActualizeCurrency") .
'</a>';
1293 if (! empty($object->frequency) && ! empty($object->date_when)) {
1294 $dateexample = $object->date_when;
1299 $substitutionarray[
'__INVOICE_PREVIOUS_MONTH__'] = $langs->trans(
"PreviousMonthOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($dateexample, -1,
'm'),
'%m') .
')';
1300 $substitutionarray[
'__INVOICE_MONTH__'] = $langs->trans(
"MonthOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date($dateexample,
'%m') .
')';
1301 $substitutionarray[
'__INVOICE_NEXT_MONTH__'] = $langs->trans(
"NextMonthOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($dateexample, 1,
'm'),
'%m') .
')';
1302 $substitutionarray[
'__INVOICE_PREVIOUS_MONTH_TEXT__'] = $langs->trans(
"TextPreviousMonthOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($dateexample, -1,
'm'),
'%B') .
')';
1303 $substitutionarray[
'__INVOICE_MONTH_TEXT__'] = $langs->trans(
"TextMonthOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date($dateexample,
'%B') .
')';
1304 $substitutionarray[
'__INVOICE_NEXT_MONTH_TEXT__'] = $langs->trans(
"TextNextMonthOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($dateexample, 1,
'm'),
'%B') .
')';
1305 $substitutionarray[
'__INVOICE_PREVIOUS_YEAR__'] = $langs->trans(
"PreviousYearOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($dateexample, -1,
'y'),
'%Y') .
')';
1306 $substitutionarray[
'__INVOICE_YEAR__'] = $langs->trans(
"YearOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date($dateexample,
'%Y') .
')';
1307 $substitutionarray[
'__INVOICE_NEXT_YEAR__'] = $langs->trans(
"NextYearOfInvoice") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree($dateexample, 1,
'y'),
'%Y') .
')';
1309 $substitutionarray[
'__INVOICE_DATE_NEXT_INVOICE_BEFORE_GEN__'] = $langs->trans(
"DateNextInvoiceBeforeGen") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(($object->date_when ? $object->date_when :
dol_now()),
'dayhour') .
')';
1310 $substitutionarray[
'__INVOICE_DATE_NEXT_INVOICE_AFTER_GEN__'] = $langs->trans(
"DateNextInvoiceAfterGen") .
' (' . $langs->trans(
"Example") .
': ' .
dol_print_date(
dol_time_plus_duree(($object->date_when ? $object->date_when :
dol_now()), $object->frequency, $object->unit_frequency),
'dayhour') .
')';
1311 $substitutionarray[
'__INVOICE_COUNTER_CURRENT__'] = $object->nb_gen_done;
1312 $substitutionarray[
'__INVOICE_COUNTER_MAX__'] = $object->nb_gen_max;
1314 $htmltext =
'<i>' . $langs->trans(
"FollowingConstantsWillBeSubstituted") .
':<br>';
1315 foreach ($substitutionarray as $key => $val) {
1316 $htmltext .= $key .
' = ' . $langs->trans($val) .
'<br>';
1318 $htmltext .=
'</i>';
1322 print $form->editfieldkey($form->textwithpicto($langs->trans(
'NotePublic'), $htmltext, 1,
'help',
'', 0, 2,
'notepublic'),
'note_public', $object->note_public, $object, $usercancreate);
1323 print
'</td><td class="wordbreak">';
1324 print $form->editfieldval($langs->trans(
"NotePublic"),
'note_public', $object->note_public, $object, $usercancreate,
'textarea:' . ROWS_4 .
':90%',
'', null, null,
'', 1);
1330 print $form->editfieldkey($form->textwithpicto($langs->trans(
"NotePrivate"), $htmltext, 1,
'help',
'', 0, 2,
'noteprivate'),
'note_private', $object->note_private, $object, $usercancreate);
1331 print
'</td><td class="wordbreak">';
1332 print $form->editfieldval($langs->trans(
"NotePrivate"),
'note_private', $object->note_private, $object, $usercancreate,
'textarea:' . ROWS_4 .
':90%',
'', null, null,
'', 1);
1337 print
'<tr><td class="nowrap">';
1338 print
'<table width="100%" class="nobordernopadding"><tr><td class="nowrap">';
1339 print $langs->trans(
'BankAccount');
1341 if ($action !=
'editbankaccount' && $usercancreate && $object->statut == FactureFournisseurRec::STATUS_NOTSUSPENDED) {
1342 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>';
1344 print
'</tr></table>';
1346 if ($action ==
'editbankaccount') {
1347 $form->formSelectAccount($_SERVER[
'PHP_SELF'] .
'?id=' . $object->id, $object->fk_account,
'fk_account', 1);
1349 $form->formSelectAccount($_SERVER[
'PHP_SELF'] .
'?id=' . $object->id, $object->fk_account,
'none');
1355 print
'<tr><td class="nowrap">';
1356 print
'<table width="100%" class="nobordernopadding"><tr><td class="nowrap">';
1357 print $langs->trans(
'Model');
1359 if ($action !=
'editmodelpdf' && $usercancreate && $object->statut == FactureFournisseurRec::STATUS_NOTSUSPENDED) {
1360 print
'<td class="right"><a class="editfielda" href="' . $_SERVER[
'PHP_SELF'] .
'?action=editmodelpdf&token=' .
newToken() .
'&id=' . $object->id .
'">' .
img_edit($langs->trans(
'SetModel'), 1) .
'</a></td>';
1362 print
'</tr></table>';
1364 if ($action ==
'editmodelpdf') {
1365 include_once DOL_DOCUMENT_ROOT .
'/core/modules/supplier_invoice/modules_facturefournisseur.php';
1368 foreach ($models as $k => $model) {
1369 $list[] = str_replace(
':',
'|', $k) .
':' . $model;
1371 $select =
'select;' . implode(
',', $list);
1373 print $form->editfieldval($langs->trans(
'Model'),
'modelpdf', $object->model_pdf, $object, $usercancreate, $select);
1375 print $object->model_pdf;
1382 include DOL_DOCUMENT_ROOT .
'/core/tpl/extrafields_view.tpl.php';
1387 print
'<div class="fichehalfright">';
1388 print
'<div class="underbanner clearboth"></div>';
1393 $title = $langs->trans(
"Recurrence");
1396 print
'<table class="border centpercent tableforfield">';
1398 print
'<tr><td colspan="2">' .
img_picto(
'',
'recurring',
'class="pictofixedwidth"') . $title .
'</td></tr>';
1401 print
'<tr><td style="width: 50%">';
1402 print
'<table class="nobordernopadding" width="100%"><tr><td>';
1403 print $langs->trans(
'Frequency');
1405 if ($action !=
'editfrequency' && $usercancreate) {
1406 print
'<td class="right"><a class="editfielda" href="' . $_SERVER[
"PHP_SELF"] .
'?action=editfrequency&token=' .
newToken() .
'&facid=' . $object->id .
'">' .
img_edit($langs->trans(
'Edit'), 1) .
'</a></td>';
1408 print
'</tr></table>';
1410 if ($action ==
'editfrequency') {
1411 print
'<form method="post" action="' . $_SERVER[
"PHP_SELF"] .
'?facid=' . $object->id .
'">';
1412 print
'<input type="hidden" name="action" value="setfrequency">';
1413 print
'<input type="hidden" name="token" value="' .
newToken() .
'">';
1414 print
'<table class="nobordernopadding">';
1416 print
"<input type='text' name='frequency' value='" . $object->frequency .
"' size='5' /> " . $form->selectarray(
'unit_frequency', array(
'd' => $langs->trans(
'Day'),
'm' => $langs->trans(
'Month'),
'y' => $langs->trans(
'Year')), ($object->unit_frequency ? $object->unit_frequency :
'm'));
1418 print
'<td class="left"><input type="submit" class="button button-edit" value="' . $langs->trans(
"Modify") .
'"></td>';
1419 print
'</tr></table></form>';
1421 if ($object->frequency > 0) {
1422 print $langs->trans(
'FrequencyPer_' . $object->unit_frequency, $object->frequency);
1424 print $langs->trans(
"NotARecurringInvoiceTemplate");
1431 if ($action ==
'date_when' || $object->frequency > 0) {
1432 print $form->editfieldkey($langs->trans(
"NextDateToExecution"),
'date_when', $object->date_when, $object, $usercancreate,
'day');
1434 print $langs->trans(
"NextDateToExecution");
1437 if ($action ==
'date_when' || $object->frequency > 0) {
1438 print $form->editfieldval($langs->trans(
"NextDateToExecution"),
'date_when', $object->date_when, $object, $usercancreate,
'day', $object->date_when, null,
'',
'', 0,
'strikeIfMaxNbGenReached');
1441 if (! $object->isMaxNbGenReached()) {
1442 if (! $object->suspended && $action !=
'editdate_when' && $object->frequency > 0 && $object->date_when && $object->date_when < $now) {
1446 print
img_info($langs->trans(
"MaxNumberOfGenerationReached"));
1453 if ($action ==
'nb_gen_max' || $object->frequency > 0) {
1454 print $form->editfieldkey($langs->trans(
"MaxPeriodNumber"),
'nb_gen_max', $object->nb_gen_max, $object, $usercancreate);
1456 print $langs->trans(
"MaxPeriodNumber");
1459 if ($action ==
'nb_gen_max' || $object->frequency > 0) {
1460 print $form->editfieldval($langs->trans(
"MaxPeriodNumber"),
'nb_gen_max', $object->nb_gen_max ? $object->nb_gen_max :
'', $object, $usercancreate);
1469 if ($action ==
'auto_validate' || $object->frequency > 0) {
1470 print $form->editfieldkey($langs->trans(
"StatusOfGeneratedInvoices"),
'auto_validate', $object->auto_validate, $object, $usercancreate);
1472 print $langs->trans(
"StatusOfGeneratedInvoices");
1475 $select =
'select;0:' . $langs->trans(
'BillStatusDraft') .
',1:' . $langs->trans(
'BillStatusValidated');
1476 if ($action ==
'auto_validate' || $object->frequency > 0) {
1477 print $form->editfieldval($langs->trans(
"StatusOfGeneratedInvoices"),
'auto_validate', $object->auto_validate, $object, $usercancreate, $select);
1481 if (! empty($conf->global->INVOICE_REC_CAN_DISABLE_DOCUMENT_FILE_GENERATION)) {
1484 if ($action ==
'generate_pdf' || $object->frequency > 0) {
1485 print $form->editfieldkey($langs->trans(
"StatusOfGeneratedDocuments"),
'generate_pdf', $object->generate_pdf, $object, $usercancreate);
1487 print $langs->trans(
"StatusOfGeneratedDocuments");
1491 $select =
'select;0:' . $langs->trans(
'DoNotGenerateDoc') .
',1:' . $langs->trans(
'AutogenerateDoc');
1492 if ($action ==
'generate_pdf' || $object->frequency > 0) {
1493 print $form->editfieldval($langs->trans(
"StatusOfGeneratedDocuments"),
'generate_pdf', $object->generate_pdf, $object, $usercancreate, $select);
1498 print
'<input type="hidden" name="generate_pdf" value="1">';
1504 if ($object->frequency > 0) {
1507 if (empty($conf->cron->enabled)) {
1508 print
info_admin($langs->trans(
"EnableAndSetupModuleCron", $langs->transnoentitiesnoconv(
"Module2300Name")));
1511 print
'<div class="underbanner clearboth"></div>';
1512 print
'<table class="border centpercent tableforfield">';
1515 print
'<tr><td style="width: 50%">' . $langs->trans(
"NbOfGenerationDone") .
'</td>';
1517 print $object->nb_gen_done ? $object->nb_gen_done :
'0';
1523 print $langs->trans(
"DateLastGeneration");
1537 print
'<div class="clearboth"></div><br>';
1540 print
' <form name="addproduct" id="addproduct" action="' . $_SERVER[
"PHP_SELF"] .
'?id=' . $object->id . (($action !=
'editline') ?
'#add' :
'#line_' .
GETPOST(
'lineid',
'int')) .
'" method="POST">
1541 <input type="hidden" name="token" value="' .
newToken() .
'">
1542 <input type="hidden" name="action" value="' . (($action !=
'editline') ?
'addline' :
'updateline') .
'">
1543 <input type="hidden" name="mode" value="">
1544 <input type="hidden" name="id" value="' . $object->id .
'">
1547 if (! empty($conf->use_javascript_ajax) && $object->statut == 0) {
1548 include DOL_DOCUMENT_ROOT .
'/core/tpl/ajaxrow.tpl.php';
1551 print
'<div class="div-table-responsive-no-min">';
1552 print
'<table id="tablelines" class="noborder noshadow" width="100%">';
1553 $object->fetch_lines();
1555 if (! empty($object->lines)) {
1556 $canchangeproduct = 1;
1558 foreach ($object->lines as $line) {
1559 $line->ref = $line->label;
1560 $line->product_label = $line->label;
1561 $line->subprice = $line->pu_ht;
1564 global $canchangeproduct;
1565 $canchangeproduct = 0;
1567 $object->statut = $object->suspended;
1568 $object->printObjectLines($action, $mysoc, $object->thirdparty, $lineid, 0);
1573 if ($object->statut == $object::STATUS_DRAFT && $usercancreate && $action !=
'valid' && $action !=
'editline') {
1574 if ($action !=
'editline') {
1577 $parameters = array();
1578 $reshook = $hookmanager->executeHooks(
'formAddObjectLine', $parameters, $object, $action);
1579 if ($reshook < 0)
setEventMessages($hookmanager->error, $hookmanager->errors,
'errors');
1580 if (empty($reshook))
1581 global $senderissupplier;
1582 $senderissupplier = 2;
1583 $object->formAddObjectLine(0, $object->thirdparty, $mysoc);
1597 print
'<div class="tabsAction">';
1599 if (empty($object->suspended)) {
1600 if ($usercancreate) {
1601 if (! empty($object->frequency) && $object->nb_gen_max > 0 && ($object->nb_gen_done >= $object->nb_gen_max)) {
1602 print
'<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="' .
dol_escape_htmltag($langs->trans(
"MaxGenerationReached")) .
'">' . $langs->trans(
"CreateBill") .
'</a></div>';
1604 if (empty($object->frequency) || $object->date_when <= $nowlasthour) {
1605 print
'<div class="inline-block divButAction"><a class="butAction" href="' . DOL_URL_ROOT .
'/fourn/facture/card.php?action=create&socid=' . $object->thirdparty->id .
'&fac_rec=' . $object->id .
'">' . $langs->trans(
"CreateBill") .
'</a></div>';
1607 print
'<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#" title="' .
dol_escape_htmltag($langs->trans(
"DateIsNotEnough")) .
'">' . $langs->trans(
"CreateBill") .
'</a></div>';
1611 print
'<div class="inline-block divButAction"><a class="butActionRefused classfortooltip" href="#">' . $langs->trans(
"CreateBill") .
'</a></div>';
1615 if ($usercancreate) {
1616 if (empty($object->suspended)) {
1617 print
'<div class="inline-block divButAction"><a class="butActionDelete" href="' . $_SERVER[
"PHP_SELF"] .
'?action=disable&id=' . $object->id .
'&token=' .
newToken() .
'">' . $langs->trans(
"Disable") .
'</a></div>';
1619 print
'<div class="inline-block divButAction"><a class="butAction" href="' . $_SERVER[
"PHP_SELF"] .
'?action=enable&id=' . $object->id .
'&token=' .
newToken() .
'">' . $langs->trans(
"Enable") .
'</a></div>';
1624 if (($user->rights->fournisseur->facture->supprimer || $user->rights->supplier_invoice->supprimer)) {
1625 print
'<div class="inline-block divButAction"><a class="butActionDelete" href="' . $_SERVER[
'PHP_SELF'] .
'?action=ask_deleteinvoice&id=' . $object->id .
'&token=' .
newToken() .
'">' . $langs->trans(
'Delete') .
'</a></div>';
1630 print
'<div class="fichecenter"><div class="fichehalfleft">';
1631 print
'<a name="builddoc"></a>';
1634 $linktoelem = $form->showLinkToObjectBlock($object, null, array(
'invoice'));
1636 $somethingshown = $form->showLinkedObjectBlock($object, $linktoelem);
1638 print
'</div></div>';
GETPOST($paramname, $check= 'alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
img_edit($titlealt= 'default', $float=0, $other= '')
Show logo editer/modifier fiche.
if($cancel &&!$id) if($action== 'add'&&!$cancel) if($action== 'delete') if($id) $form
Actions.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm= 'auto', $check=1)
Return a timestamp date built from detailed informations (by default a local PHP server timestamp) Re...
Class to manage products or services.
dol_now($mode= 'auto')
Return date for now.
Class to manage Dolibarr users.
if(!defined('NOREQUIRESOC')) if(!defined('NOREQUIRETRAN')) if(!defined('NOCSRFCHECK')) if(!defined('NOTOKENRENEWAL')) if(!defined('NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined('NOREQUIREAJAX')) llxHeader()
Empty header.
dol_clone($object, $native=0)
Create a clone of instance of object (new instance with same value for properties) With native = 0: P...
Class to manage suppliers invoices.
get_default_npr(Societe $thirdparty_seller, Societe $thirdparty_buyer, $idprod=0, $idprodfournprice=0)
Fonction qui renvoie si tva doit etre tva percue recuperable.
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags= '', $escapeonlyhtmltags=0)
Returns text escaped for inclusion in HTML alt or title tags, or into values of HTML input fields...
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...
get_localtax($vatrate, $local, $thirdparty_buyer="", $thirdparty_seller="", $vatnpr=0)
Return localtax rate for a particular vat, when selling a product with vat $vatrate, from a $thirdparty_buyer to a $thirdparty_seller Note: This function applies same rules than get_default_tva.
if(GETPOST('button_removefilter_x', 'alpha')||GETPOST('button_removefilter.x', 'alpha')||GETPOST('button_removefilter', 'alpha')) if(GETPOST('button_search_x', 'alpha')||GETPOST('button_search.x', 'alpha')||GETPOST('button_search', 'alpha')) if($action=="save"&&empty($cancel)) $help_url
View.
Class to manage supplier invoice lines of templates.
dol_time_plus_duree($time, $duration_value, $duration_unit, $ruleforendofmonth=0)
Add a delay to a date.
img_warning($titlealt= 'default', $moreatt= '', $morecss= 'pictowarning')
Show warning logo.
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...
getCommonSubstitutionArray($outputlangs, $onlykey=0, $exclude=null, $object=null)
Return array of possible common substitutions.
static getIdAndTxFromCode($dbs, $code, $date_document= '')
Get id and rate of currency from code.
setEventMessages($mesg, $mesgs, $style= 'mesgs', $messagekey= '')
Set event messages in dol_events session object.
GETPOSTISSET($paramname)
Return true if we are in a context of submitting the parameter $paramname from a POST of a form...
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...
Class to manage third parties objects (customers, suppliers, prospects...)
info_admin($text, $infoonimgalt=0, $nodiv=0, $admin= '1', $morecss= 'hideonsmartphone', $textfordropdown= '')
Show information for admin users or standard users.
Class to manage projects.
load_fiche_titre($titre, $morehtmlright= '', $picto= 'generic', $pictoisfullpath=0, $id= '', $morecssontable= '', $morehtmlcenter= '')
Load a title with picto.
price2num($amount, $rounding= '', $option=0)
Function that return a number with universal decimal format (decimal separator is '...
img_picto($titlealt, $picto, $moreatt= '', $pictoisfullpath=false, $srconly=0, $notitle=0, $alt= '', $morecss= '', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
Class to manage invoice templates.
Class to manage translations.
restrictedArea($user, $features, $objectid=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.
static liste_modeles($db, $maxfilenamelength=0)
Return list of active generation models.
dol_get_fiche_head($links=array(), $active= '', $title= '', $notab=0, $picto= '', $pictoisfullpath=0, $morehtmlright= '', $morecss= '', $limittoshow=0, $moretabssuffix= '')
Show tabs of a record.
div float
Buy price without taxes.
dol_print_date($time, $format= '', $tzoutput= 'auto', $outputlangs= '', $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
supplier_invoice_rec_prepare_head($object)
Return array head with list of tabs to view object informations.
dol_htmlcleanlastbr($stringtodecode)
This function remove all ending and br at end.
dol_print_error($db= '', $error= '', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
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...
img_info($titlealt= 'default')
Show info logo.
newToken()
Return the value of token currently saved into session with name 'newtoken'.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
Class to manage a WYSIWYG editor.
dol_banner_tab($object, $paramid, $morehtml= '', $shownav=1, $fieldid= 'rowid', $fieldref= 'ref', $morehtmlref= '', $moreparam= '', $nodbprefix=0, $morehtmlleft= '', $morehtmlstatus= '', $onlybanner=0, $morehtmlright= '')
Show tab footer of a card.
$formconfirm
if ($action == 'delbookkeepingyear') {
getCountry($searchkey, $withcode= '', $dbtouse=0, $outputlangs= '', $entconv=1, $searchlabel= '')
Return country label, code or id from an id, code or label.
Class to manage predefined suppliers products.