41require_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.product.class.php';
42require_once DOL_DOCUMENT_ROOT.
'/core/class/commonobject.class.php';
43require_once DOL_DOCUMENT_ROOT.
'/product/class/product.class.php';
44require_once DOL_DOCUMENT_ROOT.
'/contact/class/contact.class.php';
45require_once DOL_DOCUMENT_ROOT.
'/margin/lib/margins.lib.php';
46require_once DOL_DOCUMENT_ROOT.
'/multicurrency/class/multicurrency.class.php';
47require_once DOL_DOCUMENT_ROOT.
'/core/class/commonincoterm.class.php';
48require_once DOL_DOCUMENT_ROOT.
'/subtotals/class/commonsubtotal.class.php';
54 use CommonIncoterm, CommonSubtotal;
59 public $element =
'supplier_proposal';
64 public $table_element =
'supplier_proposal';
69 public $table_element_line =
'supplier_proposaldet';
74 public $class_element_line =
'SupplierProposalLine';
78 public $fk_element =
'fk_supplier_proposal';
83 public $picto =
'supplier_proposal';
89 public $restrictiononfksoc = 1;
115 public $ref_supplier;
131 public $delivery_date;
150 public $user_author_id;
176 public $cond_reglement_code;
180 public $cond_reglement_doc;
185 public $mode_reglement_code;
190 public $mode_reglement;
197 public $deposit_percent;
203 public $extraparams = array();
208 public $lines = array();
215 public $labelStatus = array();
216 public $labelStatusShort = array();
231 public $fk_multicurrency;
236 public $multicurrency_code;
240 public $multicurrency_tx;
244 public $multicurrency_total_ht;
248 public $multicurrency_total_tva;
252 public $multicurrency_total_ttc;
254 public $fields = array(
255 'ref' => array(
'type' =>
'varchar(255)',
'label' =>
'Ref',
'enabled' => 1,
'visible' => 1,
'showoncombobox' => 1,
'position' => 25,
'searchall' => 1),
256 'note_public' => array(
'type' =>
'html',
'label' =>
'NotePublic',
'enabled' => 1,
'visible' => 0,
'position' => 750,
'searchall' => 1),
293 public function __construct($db, $socid = 0, $supplier_proposalid = 0)
297 $this->ismultientitymanaged = 1;
298 $this->socid = $socid;
299 $this->
id = $supplier_proposalid;
314 public function add_product($idproduct, $qty, $remise_percent = 0)
323 dol_syslog(get_class($this).
"::add_product $idproduct, $qty, $remise_percent");
324 if ($idproduct > 0) {
326 $prod->fetch($idproduct);
328 $productdesc =
$prod->description;
332 if (empty($tva_tx)) {
340 $price =
$prod->multiprices[$this->thirdparty->price_level];
342 $price =
$prod->price;
347 $line->fk_product = $idproduct;
348 $line->desc = $productdesc;
350 $line->subprice = $price;
351 $line->remise_percent = $remise_percent;
352 $line->tva_tx = $tva_tx;
354 $this->lines[] = $line;
372 include_once DOL_DOCUMENT_ROOT.
'/core/lib/price.lib.php';
373 include_once DOL_DOCUMENT_ROOT.
'/core/class/discount.class.php';
378 $result = $remise->fetch($idremise);
381 if ($remise->fk_facture) {
382 $this->error = $langs->trans(
"ErrorDiscountAlreadyUsed");
383 $this->db->rollback();
388 $supplier_proposalligne->fk_supplier_proposal = $this->id;
389 $supplier_proposalligne->fk_remise_except = $remise->id;
390 $supplier_proposalligne->desc = $remise->description;
391 $supplier_proposalligne->tva_tx = $remise->tva_tx;
392 $supplier_proposalligne->localtax1_tx = $remise->localtax1_tx;
393 $supplier_proposalligne->localtax1_type = $remise->localtax1_type;
394 $supplier_proposalligne->localtax2_tx = $remise->localtax1_tx;
395 $supplier_proposalligne->localtax2_type = $remise->localtax1_type;
396 $supplier_proposalligne->subprice = -(float) $remise->amount_ht;
397 $supplier_proposalligne->fk_product = 0;
398 $supplier_proposalligne->qty = 1;
399 $supplier_proposalligne->remise_percent = 0;
400 $supplier_proposalligne->rang = -1;
401 $supplier_proposalligne->info_bits = 2;
403 $supplier_proposalligne->total_ht = -(float) $remise->amount_ht;
404 $supplier_proposalligne->total_tva = -(float) $remise->amount_tva;
405 $supplier_proposalligne->total_ttc = -(float) $remise->amount_ttc;
406 $supplier_proposalligne->total_localtax1 = -(float) $remise->total_localtax1;
407 $supplier_proposalligne->total_localtax2 = -(float) $remise->total_localtax2;
409 $result = $supplier_proposalligne->insert();
416 $this->db->rollback();
421 $this->db->rollback();
425 $this->db->rollback();
466 public function addline($desc, $pu_ht, $qty, $txtva, $txlocaltax1 = 0, $txlocaltax2 = 0, $fk_product = 0, $remise_percent = 0, $price_base_type =
'HT', $pu_ttc = 0, $info_bits = 0, $type = 0, $rang = -1, $special_code = 0, $fk_parent_line = 0, $fk_fournprice = 0, $pa_ht = 0, $label =
'', $array_options = [], $ref_supplier =
'', $fk_unit = 0, $origin =
'', $origin_id = 0, $pu_ht_devise = 0,
$date_start = 0, $date_end = 0)
470 dol_syslog(get_class($this).
"::addline supplier_proposalid=$this->id, desc=$desc, pu_ht=$pu_ht, qty=$qty, txtva=$txtva, fk_product=$fk_product, remise_except=$remise_percent, price_base_type=$price_base_type, pu_ttc=$pu_ttc, info_bits=$info_bits, type=$type");
471 include_once DOL_DOCUMENT_ROOT.
'/core/lib/price.lib.php';
474 if (empty($remise_percent)) {
480 if (empty($info_bits)) {
486 if (empty($fk_parent_line) || $fk_parent_line < 0) {
493 $remise_percent =
price2num($remise_percent);
497 if (!preg_match(
'/\((.*)\)/', (
string) $txtva)) {
503 if ($price_base_type ==
'HT') {
514 if ($this->
status == self::STATUS_DRAFT) {
517 if ($fk_product > 0) {
518 if (
getDolGlobalInt(
'SUPPLIER_PROPOSAL_WITH_PREDEFINED_PRICES_ONLY') == 1) {
520 dol_syslog(get_class($this).
"::addline we check supplier prices fk_product=".$fk_product.
" fk_fournprice=".$fk_fournprice.
" qty=".$qty.
" ref_supplier=".$ref_supplier);
522 if ($productsupplier->fetch($fk_product) > 0) {
523 $product_type = $productsupplier->type;
524 $label = $productsupplier->label;
525 $fk_prod_fourn_price = $fk_fournprice;
530 $result = $productsupplier->get_buyprice($fk_prod_fourn_price, $qty, $fk_product,
'none', $this->socid);
532 $pu = $productsupplier->fourn_pu;
533 $ref_supplier = $productsupplier->ref_supplier;
535 if ($remise_percent == 0 && $productsupplier->remise_percent != 0) {
536 $remise_percent = $productsupplier->remise_percent;
540 $langs->load(
"errors");
541 $this->error =
"Ref ".$productsupplier->ref.
" ".$langs->trans(
"ErrorQtyTooLowForThisSupplier");
542 $this->db->rollback();
543 dol_syslog(get_class($this).
"::addline we did not found supplier price, so we can't guess unit price");
549 $langs->load(
"errors");
550 $this->error =
"Ref ".$productsupplier->ref.
" ".$langs->trans(
"ErrorQtyTooLowForThisSupplier");
551 $this->db->rollback();
552 dol_syslog(get_class($this).
"::addline result=".$result.
" - ".$this->error, LOG_DEBUG);
557 $this->db->rollback();
558 dol_syslog(get_class($this).
"::addline result=".$result.
" - ".$this->error, LOG_ERR);
563 $this->db->rollback();
568 $product_type = $type;
580 if (preg_match(
'/\((.*)\)/', $txtva, $reg)) {
581 $vat_src_code = $reg[1];
582 $txtva = preg_replace(
'/\s*\(.*\)/',
'', $txtva);
585 if (
isModEnabled(
"multicurrency") && $pu_ht_devise > 0) {
592 (
float) $remise_percent,
594 (
float) $txlocaltax1,
595 (
float) $txlocaltax2,
603 (
float) $this->multicurrency_tx,
606 $total_ht = $tabprice[0];
607 $total_tva = $tabprice[1];
608 $total_ttc = $tabprice[2];
609 $total_localtax1 = $tabprice[9];
610 $total_localtax2 = $tabprice[10];
611 $pu = $pu_ht = $tabprice[3];
614 $multicurrency_total_ht = $tabprice[16];
615 $multicurrency_total_tva = $tabprice[17];
616 $multicurrency_total_ttc = $tabprice[18];
617 $pu_ht_devise = $tabprice[19];
621 if ($ranktouse == -1) {
622 $rangmax = $this->
line_max($fk_parent_line);
623 $ranktouse = $rangmax + 1;
629 $this->line->fk_supplier_proposal = $this->id;
630 $this->line->label = $label;
631 $this->line->desc = $desc;
632 $this->line->qty = $qty;
634 $this->line->vat_src_code = $vat_src_code;
635 $this->line->tva_tx = $txtva;
636 $this->line->localtax1_tx = ($total_localtax1 ? $localtaxes_type[1] : 0);
637 $this->line->localtax2_tx = ($total_localtax2 ? $localtaxes_type[3] : 0);
638 $this->line->localtax1_type = empty($localtaxes_type[0]) ?
'' : $localtaxes_type[0];
639 $this->line->localtax2_type = empty($localtaxes_type[2]) ?
'' : $localtaxes_type[2];
640 $this->line->fk_product = $fk_product;
641 $this->line->remise_percent = $remise_percent;
642 $this->line->subprice = (float) $pu_ht;
643 $this->line->rang = $ranktouse;
644 $this->line->info_bits = $info_bits;
645 $this->line->total_ht = (float) $total_ht;
646 $this->line->total_tva = (float) $total_tva;
647 $this->line->total_localtax1 = (float) $total_localtax1;
648 $this->line->total_localtax2 = (float) $total_localtax2;
649 $this->line->total_ttc = (float) $total_ttc;
650 $this->line->product_type = $type;
651 $this->line->special_code = $special_code;
652 $this->line->fk_parent_line = $fk_parent_line;
653 $this->line->fk_unit = $fk_unit;
654 $this->line->origin = $origin;
655 $this->line->origin_type = $origin;
656 $this->line->origin_id = $origin_id;
657 $this->line->ref_fourn = $this->db->escape($ref_supplier);
659 $this->line->date_end = $date_end;
662 if (!empty($fk_product) && $fk_product > 0 && empty($fk_fournprice) && empty($pa_ht)) {
664 include_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.product.class.php';
666 $productFournisseur->find_min_price_product_fournisseur($fk_product);
667 $this->line->fk_fournprice = $productFournisseur->product_fourn_price_id;
669 $this->line->fk_fournprice = ($fk_fournprice > 0 ? $fk_fournprice : 0);
671 $this->line->pa_ht = $pa_ht;
675 $this->line->fk_multicurrency = $this->fk_multicurrency;
676 $this->line->multicurrency_code = $this->multicurrency_code;
677 $this->line->multicurrency_subprice = (float) $pu_ht_devise;
678 $this->line->multicurrency_total_ht = (float) $multicurrency_total_ht;
679 $this->line->multicurrency_total_tva = (float) $multicurrency_total_tva;
680 $this->line->multicurrency_total_ttc = (float) $multicurrency_total_ttc;
683 if (empty($qty) && empty($special_code)) {
684 $this->line->special_code = 3;
687 if (is_array($array_options) && count($array_options) > 0) {
688 $this->line->array_options = $array_options;
691 $result = $this->line->insert();
694 if (!empty($fk_parent_line)) {
696 } elseif ($ranktouse > 0 && $ranktouse <= count($this->lines)) {
697 $linecount = count($this->lines);
698 for ($ii = $ranktouse; $ii <= $linecount; $ii++) {
704 $result = $this->
update_price(1,
'auto', 0, $this->thirdparty);
707 return $this->line->id;
709 $this->db->rollback();
714 $this->db->rollback();
718 $this->error =
'BadStatusOfObjectToAddLine';
750 public function updateline($rowid, $pu, $qty, $remise_percent, $txtva, $txlocaltax1 = 0, $txlocaltax2 = 0, $desc =
'', $price_base_type =
'HT', $info_bits = 0, $special_code = 0, $fk_parent_line = 0, $skip_update_total = 0, $fk_fournprice = 0, $pa_ht = 0, $label =
'', $type = 0, $array_options = [], $ref_supplier =
'', $fk_unit = 0, $pu_ht_devise = 0)
754 dol_syslog(get_class($this).
"::updateLine $rowid, $pu, $qty, $remise_percent, $txtva, $desc, $price_base_type, $info_bits");
755 include_once DOL_DOCUMENT_ROOT.
'/core/lib/price.lib.php';
758 $remise_percent =
price2num($remise_percent);
761 if (!preg_match(
'/\((.*)\)/', (
string) $txtva)) {
767 if (empty($qty) && empty($special_code)) {
770 if (!empty($qty) && $special_code == 3) {
786 if (preg_match(
'/\((.*)\)/', $txtva, $reg)) {
787 $vat_src_code = $reg[1];
788 $txtva = preg_replace(
'/\s*\(.*\)/',
'', $txtva);
791 if (
isModEnabled(
"multicurrency") && $pu_ht_devise > 0) {
798 (
float) $remise_percent,
800 (
float) $txlocaltax1,
801 (
float) $txlocaltax2,
809 (
float) $this->multicurrency_tx,
812 $total_ht = $tabprice[0];
813 $total_tva = $tabprice[1];
814 $total_ttc = $tabprice[2];
815 $total_localtax1 = $tabprice[9];
816 $total_localtax2 = $tabprice[10];
817 $pu_ht = $tabprice[3];
818 $pu_tva = $tabprice[4];
819 $pu_ttc = $tabprice[5];
822 $multicurrency_total_ht = $tabprice[16];
823 $multicurrency_total_tva = $tabprice[17];
824 $multicurrency_total_ttc = $tabprice[18];
825 $pu_ht_devise = $tabprice[19];
828 if ($price_base_type ==
'TTC') {
834 $line->fetch($rowid);
835 $line->fetch_optionals();
837 $fk_product = $line->fk_product;
840 $staticline = clone $line;
842 $line->oldline = $staticline;
844 $this->line->context = $this->context;
847 if (!empty($fk_parent_line) && !empty($staticline->fk_parent_line) && $fk_parent_line != $staticline->fk_parent_line) {
848 $rangmax = $this->
line_max($fk_parent_line);
849 $this->line->rang = $rangmax + 1;
852 $this->line->id = $rowid;
853 $this->line->label = $label;
854 $this->line->desc = $desc;
855 $this->line->qty = $qty;
856 $this->line->product_type = $type;
858 $this->line->vat_src_code = $vat_src_code;
859 $this->line->tva_tx = $txtva;
860 $this->line->localtax1_tx = $txlocaltax1;
861 $this->line->localtax2_tx = $txlocaltax2;
862 $this->line->localtax1_type = empty($localtaxes_type[0]) ?
'' : $localtaxes_type[0];
863 $this->line->localtax2_type = empty($localtaxes_type[2]) ?
'' : $localtaxes_type[2];
864 $this->line->remise_percent = $remise_percent;
865 $this->line->subprice = (float) $pu;
866 $this->line->info_bits = $info_bits;
867 $this->line->total_ht = (float) $total_ht;
868 $this->line->total_tva = (float) $total_tva;
869 $this->line->total_localtax1 = (float) $total_localtax1;
870 $this->line->total_localtax2 = (float) $total_localtax2;
871 $this->line->total_ttc = (float) $total_ttc;
872 $this->line->special_code = $special_code;
873 $this->line->fk_parent_line = $fk_parent_line;
874 $this->line->skip_update_total = $skip_update_total;
875 $this->line->ref_fourn = $ref_supplier;
876 $this->line->fk_unit = $fk_unit;
879 if (!empty($fk_product) && $fk_product > 0 && empty($fk_fournprice) && empty($pa_ht)) {
881 include_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.product.class.php';
883 $productFournisseur->find_min_price_product_fournisseur($fk_product);
884 $this->line->fk_fournprice = $productFournisseur->product_fourn_price_id;
886 $this->line->fk_fournprice = $fk_fournprice;
888 $this->line->pa_ht = $pa_ht;
890 if (is_array($array_options) && count($array_options) > 0) {
892 foreach ($array_options as $key => $value) {
893 $this->line->array_options[$key] = $array_options[$key];
898 $this->line->multicurrency_subprice = (float) $pu_ht_devise;
899 $this->line->multicurrency_total_ht = (float) $multicurrency_total_ht;
900 $this->line->multicurrency_total_tva = (float) $multicurrency_total_tva;
901 $this->line->multicurrency_total_ttc = (float) $multicurrency_total_ttc;
903 $result = $this->line->update();
906 if (!empty($fk_parent_line)) {
915 $this->error = $this->db->error();
916 $this->db->rollback();
920 dol_syslog(get_class($this).
"::updateline Erreur -2 SupplierProposal en mode incompatible pour cette action");
940 $line->fetch($lineid);
942 if ($line->delete($user) > 0) {
963 public function create($user, $notrigger = 0)
975 $this->error =
"Failed to fetch company";
976 dol_syslog(get_class($this).
"::create ".$this->error, LOG_ERR);
979 if (!empty($this->
ref)) {
982 $this->error =
'ErrorRefAlreadyExists';
983 dol_syslog(get_class($this).
"::create ".$this->error, LOG_WARNING);
984 $this->db->rollback();
990 $delivery_date = $this->delivery_date;
993 if (!empty($this->multicurrency_code)) {
996 if (empty($this->fk_multicurrency)) {
998 $this->fk_multicurrency = 0;
999 $this->multicurrency_tx = 1;
1005 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"supplier_proposal (";
1008 $sql .=
", total_tva";
1009 $sql .=
", total_ttc";
1012 $sql .=
", fk_user_author";
1013 $sql .=
", note_private";
1014 $sql .=
", note_public";
1015 $sql .=
", model_pdf";
1016 $sql .=
", fk_cond_reglement";
1017 $sql .=
", deposit_percent";
1018 $sql .=
", fk_mode_reglement";
1019 $sql .=
", fk_account";
1020 $sql .=
", date_livraison";
1021 $sql .=
", fk_shipping_method";
1022 $sql .=
", fk_projet";
1024 $sql .=
", fk_multicurrency";
1025 $sql .=
", multicurrency_code";
1026 $sql .=
", multicurrency_tx";
1028 $sql .=
" VALUES (";
1029 $sql .= ((int) $this->socid);
1033 $sql .=
", '".$this->db->idate($now).
"'";
1034 $sql .=
", '(PROV)'";
1035 $sql .=
", ".($user->id > 0 ? ((int) $user->id) :
"null");
1036 $sql .=
", '".$this->db->escape($this->note_private).
"'";
1037 $sql .=
", '".$this->db->escape($this->note_public).
"'";
1038 $sql .=
", '".$this->db->escape($this->model_pdf).
"'";
1039 $sql .=
", ".($this->cond_reglement_id > 0 ? ((int) $this->cond_reglement_id) :
'NULL');
1040 $sql .=
", ".(!empty($this->deposit_percent) ?
"'" . $this->db->escape($this->deposit_percent) .
"'" :
'NULL');
1041 $sql .=
", ".($this->mode_reglement_id > 0 ? ((int) $this->mode_reglement_id) :
'NULL');
1042 $sql .=
", ".($this->fk_account > 0 ? ((int) $this->fk_account) :
'NULL');
1043 $sql .=
", ".(isDolTms($delivery_date) ?
"'".$this->db->idate($delivery_date).
"'" :
"null");
1044 $sql .=
", ".($this->shipping_method_id > 0 ? ((int) $this->shipping_method_id) :
'NULL');
1045 $sql .=
", ".($this->fk_project > 0 ? ((int) $this->fk_project) :
"null");
1046 $sql .=
", ".((int)
$conf->entity);
1047 $sql .=
", ".((int) $this->fk_multicurrency);
1048 $sql .=
", '".$this->db->escape($this->multicurrency_code).
"'";
1049 $sql .=
", ".((float) $this->multicurrency_tx);
1052 dol_syslog(get_class($this).
"::create", LOG_DEBUG);
1053 $resql = $this->db->query($sql);
1055 $this->
id = $this->db->last_insert_id(MAIN_DB_PREFIX.
"supplier_proposal");
1058 $this->
ref =
'(PROV'.$this->id.
')';
1059 $sql =
'UPDATE '.MAIN_DB_PREFIX.
"supplier_proposal SET ref='".$this->db->escape($this->
ref).
"' WHERE rowid=".((int) $this->
id);
1061 dol_syslog(get_class($this).
"::create", LOG_DEBUG);
1062 $resql = $this->db->query($sql);
1067 if (!empty($this->linkedObjectsIds) && empty($this->linked_objects)) {
1068 $this->linked_objects = $this->linkedObjectsIds;
1072 if (!$error && $this->
id && !empty($this->linked_objects) && is_array($this->linked_objects)) {
1073 foreach ($this->linked_objects as $origin => $tmp_origin_id) {
1074 if (is_array($tmp_origin_id)) {
1075 foreach ($tmp_origin_id as $origin_id) {
1090 $fk_parent_line = 0;
1091 $num = count($this->lines);
1093 for ($i = 0; $i < $num; $i++) {
1095 if (($this->lines[$i]->product_type != 9 && empty($this->lines[$i]->fk_parent_line)) || $this->lines[$i]->product_type == 9) {
1096 $fk_parent_line = 0;
1100 $this->lines[$i]->desc,
1101 $this->lines[$i]->subprice,
1102 $this->lines[$i]->qty,
1103 $this->lines[$i]->tva_tx,
1104 $this->lines[$i]->localtax1_tx,
1105 $this->lines[$i]->localtax2_tx,
1106 $this->lines[$i]->fk_product,
1107 $this->lines[$i]->remise_percent,
1111 $this->lines[$i]->product_type,
1112 $this->lines[$i]->rang,
1113 $this->lines[$i]->special_code,
1115 $this->lines[$i]->fk_fournprice,
1116 $this->lines[$i]->pa_ht,
1117 empty($this->lines[$i]->label) ?
'' : $this->lines[$i]->label,
1118 $this->lines[$i]->array_options,
1119 $this->lines[$i]->ref_fourn,
1120 $this->lines[$i]->fk_unit,
1121 'supplier_proposal',
1122 $this->lines[$i]->rowid
1127 $this->error = $this->db->error;
1132 if ($result > 0 && $this->lines[$i]->product_type == 9) {
1133 $fk_parent_line = $result;
1152 if (!$error && !$notrigger) {
1154 $result = $this->call_trigger(
'PROPOSAL_SUPPLIER_CREATE', $user);
1161 $this->error = $this->db->lasterror();
1166 $this->error = $this->db->lasterror();
1171 $this->db->commit();
1172 dol_syslog(get_class($this).
"::create done id=".$this->
id);
1175 $this->db->rollback();
1179 $this->error = $this->db->lasterror();
1180 $this->db->rollback();
1194 global $hookmanager;
1202 foreach ($this->lines as $line) {
1203 $line->fetch_optionals();
1207 $objFrom = clone $this;
1209 $objsoc =
new Societe($this->db);
1212 if (!empty($fromid) && $fromid != $this->socid) {
1213 if ($objsoc->fetch($fromid) > 0) {
1214 $this->socid = $objsoc->id;
1215 $this->cond_reglement_id = (!empty($objsoc->cond_reglement_id) ? $objsoc->cond_reglement_id : 0);
1216 $this->deposit_percent = (!empty($objsoc->deposit_percent) ? $objsoc->deposit_percent : 0);
1217 $this->mode_reglement_id = (!empty($objsoc->mode_reglement_id) ? $objsoc->mode_reglement_id : 0);
1218 unset($this->fk_project);
1223 $objsoc->fetch($this->socid);
1230 if (!
getDolGlobalString(
'SUPPLIER_PROPOSAL_ADDON') || !is_readable(DOL_DOCUMENT_ROOT.
"/core/modules/supplier_proposal/" .
getDolGlobalString(
'SUPPLIER_PROPOSAL_ADDON').
".php")) {
1231 $this->error =
'ErrorSetupNotComplete';
1236 $this->user_author_id = $user->id;
1237 $this->user_validation_id = 0;
1241 require_once DOL_DOCUMENT_ROOT.
"/core/modules/supplier_proposal/" .
getDolGlobalString(
'SUPPLIER_PROPOSAL_ADDON').
'.php';
1243 $modSupplierProposal =
new $obj();
1244 '@phan-var-force ModeleNumRefSupplierProposal $modSupplierProposal';
1245 $this->
ref = $modSupplierProposal->getNextValue($objsoc, $this);
1248 $this->context[
'createfromclone'] =
'createfromclone';
1249 $result = $this->
create($user);
1256 if (is_object($hookmanager)) {
1257 $parameters = array(
'objFrom' => $objFrom);
1259 $reshook = $hookmanager->executeHooks(
'createFrom', $parameters, $this, $action);
1267 unset($this->context[
'createfromclone']);
1271 $this->db->commit();
1274 $this->db->rollback();
1286 public function fetch($rowid, $ref =
'')
1288 $sql =
"SELECT p.rowid, p.entity, p.ref, p.fk_soc as socid";
1289 $sql .=
", p.total_ttc, p.total_tva, p.localtax1, p.localtax2, p.total_ht";
1290 $sql .=
", p.datec, GREATEST(p.tms, pef.tms) as date_modification";
1291 $sql .=
", p.date_valid as datev";
1292 $sql .=
", p.date_livraison as delivery_date";
1293 $sql .=
", p.model_pdf, p.extraparams";
1294 $sql .=
", p.note_private, p.note_public";
1295 $sql .=
", p.fk_projet as fk_project, p.fk_statut as status";
1296 $sql .=
", p.fk_user_author, p.fk_user_modif, p.fk_user_valid, p.fk_user_cloture";
1297 $sql .=
", p.fk_cond_reglement";
1298 $sql .=
", p.fk_mode_reglement";
1299 $sql .=
', p.fk_account';
1300 $sql .=
", p.fk_shipping_method";
1301 $sql .=
", p.last_main_doc";
1302 $sql .=
", p.fk_multicurrency, p.multicurrency_code, p.multicurrency_tx, p.multicurrency_total_ht, p.multicurrency_total_tva, p.multicurrency_total_ttc";
1303 $sql .=
", c.label as statut_label";
1304 $sql .=
", cr.code as cond_reglement_code, cr.libelle as cond_reglement, cr.libelle_facture as cond_reglement_libelle_doc, p.deposit_percent";
1305 $sql .=
", cp.code as mode_reglement_code, cp.libelle as mode_reglement";
1306 $sql .=
" FROM ".MAIN_DB_PREFIX.
"c_propalst as c, ".MAIN_DB_PREFIX.
"supplier_proposal as p";
1307 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"supplier_proposal_extrafields as pef ON pef.fk_object=p.rowid";
1308 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_paiement as cp ON p.fk_mode_reglement = cp.id';
1309 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_payment_term as cr ON p.fk_cond_reglement = cr.rowid';
1310 $sql .=
" WHERE p.fk_statut = c.id";
1311 $sql .=
" AND p.entity IN (".getEntity(
'supplier_proposal').
")";
1313 $sql .=
" AND p.ref = '".$this->db->escape($ref).
"'";
1315 $sql .=
" AND p.rowid = ".((int) $rowid);
1318 dol_syslog(get_class($this).
"::fetch", LOG_DEBUG);
1319 $resql = $this->db->query($sql);
1321 if ($this->db->num_rows($resql)) {
1322 $obj = $this->db->fetch_object($resql);
1324 $this->
id = $obj->rowid;
1325 $this->entity = $obj->entity;
1327 $this->
ref = $obj->ref;
1328 $this->total_ht = $obj->total_ht;
1329 $this->total_tva = $obj->total_tva;
1330 $this->total_localtax1 = $obj->localtax1;
1331 $this->total_localtax2 = $obj->localtax2;
1332 $this->total_ttc = $obj->total_ttc;
1333 $this->socid = $obj->socid;
1334 $this->fk_project = $obj->fk_project;
1335 $this->model_pdf = $obj->model_pdf;
1336 $this->note = $obj->note_private;
1337 $this->note_private = $obj->note_private;
1338 $this->note_public = $obj->note_public;
1339 $this->statut = (int) $obj->status;
1340 $this->
status = (int) $obj->status;
1341 $this->datec = $this->db->jdate($obj->datec);
1342 $this->datev = $this->db->jdate($obj->datev);
1343 $this->date_creation = $this->db->jdate($obj->datec);
1344 $this->date_modification = $this->db->jdate($obj->date_modification);
1345 $this->
date = $this->date_creation;
1346 $this->date_validation = $this->db->jdate($obj->datev);
1347 $this->delivery_date = $this->db->jdate($obj->delivery_date);
1348 $this->shipping_method_id = ($obj->fk_shipping_method > 0) ? $obj->fk_shipping_method :
null;
1350 $this->last_main_doc = $obj->last_main_doc;
1351 $this->mode_reglement_id = $obj->fk_mode_reglement;
1352 $this->mode_reglement_code = $obj->mode_reglement_code;
1353 $this->mode_reglement = $obj->mode_reglement;
1354 $this->deposit_percent = $obj->deposit_percent;
1355 $this->fk_account = ($obj->fk_account > 0) ? $obj->fk_account :
null;
1356 $this->cond_reglement_id = $obj->fk_cond_reglement;
1357 $this->cond_reglement_code = $obj->cond_reglement_code;
1358 $this->cond_reglement = $obj->cond_reglement;
1359 $this->cond_reglement_doc = $obj->cond_reglement_libelle_doc;
1361 $this->extraparams = (array) (!empty($obj->extraparams) ? json_decode($obj->extraparams,
true) : array());
1363 $this->user_author_id = $obj->fk_user_author;
1364 $this->user_modification_id = $obj->fk_user_modif;
1365 $this->user_validation_id = $obj->fk_user_valid;
1366 $this->user_closing_id = $obj->fk_user_cloture;
1369 $this->fk_multicurrency = $obj->fk_multicurrency;
1370 $this->multicurrency_code = $obj->multicurrency_code;
1371 $this->multicurrency_tx = $obj->multicurrency_tx;
1372 $this->multicurrency_total_ht = $obj->multicurrency_total_ht;
1373 $this->multicurrency_total_tva = $obj->multicurrency_total_tva;
1374 $this->multicurrency_total_ttc = $obj->multicurrency_total_ttc;
1380 $this->db->free($resql);
1382 $this->lines = array();
1385 $sql =
"SELECT d.rowid, d.fk_supplier_proposal, d.fk_parent_line, d.label as custom_label, d.description, d.price, d.tva_tx, d.localtax1_tx, d.localtax2_tx, d.qty, d.fk_remise_except, d.remise_percent, d.subprice, d.fk_product,";
1386 $sql .=
" d.info_bits, d.total_ht, d.total_tva, d.total_localtax1, d.total_localtax2, d.total_ttc, d.fk_product_fournisseur_price as fk_fournprice, d.buy_price_ht as pa_ht, d.special_code, d.rang, d.product_type,";
1387 $sql .=
' p.ref as product_ref, p.description as product_desc, p.fk_product_type, p.label as product_label,';
1388 $sql .=
' d.ref_fourn as ref_produit_fourn, d.extraparams,';
1389 $sql .=
' d.fk_multicurrency, d.multicurrency_code, d.multicurrency_subprice, d.multicurrency_total_ht, d.multicurrency_total_tva, d.multicurrency_total_ttc, d.fk_unit';
1390 $sql .=
" FROM ".MAIN_DB_PREFIX.
"supplier_proposaldet as d";
1391 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"product as p ON d.fk_product = p.rowid";
1392 $sql .=
" WHERE d.fk_supplier_proposal = ".((int) $this->
id);
1393 $sql .=
" ORDER by d.rang";
1395 $result = $this->db->query($sql);
1397 $num = $this->db->num_rows($result);
1401 $objp = $this->db->fetch_object($result);
1405 $line->rowid = $objp->rowid;
1406 $line->id = $objp->rowid;
1407 $line->fk_supplier_proposal = $objp->fk_supplier_proposal;
1408 $line->fk_parent_line = $objp->fk_parent_line;
1409 $line->product_type = $objp->product_type;
1410 $line->label = $objp->custom_label;
1411 $line->desc = $objp->description;
1412 $line->qty = $objp->qty;
1413 $line->tva_tx = $objp->tva_tx;
1414 $line->localtax1_tx = $objp->localtax1_tx;
1415 $line->localtax2_tx = $objp->localtax2_tx;
1416 $line->subprice = $objp->subprice;
1417 $line->fk_remise_except = $objp->fk_remise_except;
1418 $line->remise_percent = $objp->remise_percent;
1420 $line->info_bits = $objp->info_bits;
1421 $line->total_ht = $objp->total_ht;
1422 $line->total_tva = $objp->total_tva;
1423 $line->total_localtax1 = $objp->total_localtax1;
1424 $line->total_localtax2 = $objp->total_localtax2;
1425 $line->total_ttc = $objp->total_ttc;
1426 $line->fk_fournprice = $objp->fk_fournprice;
1427 $marginInfos =
getMarginInfos($objp->subprice, $objp->remise_percent, $objp->tva_tx, $objp->localtax1_tx, $objp->localtax2_tx, $line->fk_fournprice, $objp->pa_ht);
1428 $line->pa_ht = $marginInfos[0];
1429 $line->marge_tx = $marginInfos[1];
1430 $line->marque_tx = $marginInfos[2];
1431 $line->special_code = $objp->special_code;
1432 $line->rang = $objp->rang;
1434 $line->fk_product = $objp->fk_product;
1436 $line->ref = $objp->product_ref;
1437 $line->product_ref = $objp->product_ref;
1438 $line->libelle = $objp->product_label;
1439 $line->product_label = $objp->product_label;
1440 $line->product_desc = $objp->product_desc;
1441 $line->fk_product_type = $objp->fk_product_type;
1443 $line->ref_fourn = $objp->ref_produit_fourn;
1445 $line->extraparams = !empty($objp->extraparams) ? (array) json_decode($objp->extraparams,
true) : array();
1448 $line->fk_multicurrency = $objp->fk_multicurrency;
1449 $line->multicurrency_code = $objp->multicurrency_code;
1450 $line->multicurrency_subprice = $objp->multicurrency_subprice;
1451 $line->multicurrency_total_ht = $objp->multicurrency_total_ht;
1452 $line->multicurrency_total_tva = $objp->multicurrency_total_tva;
1453 $line->multicurrency_total_ttc = $objp->multicurrency_total_ttc;
1454 $line->fk_unit = $objp->fk_unit;
1456 $line->fetch_optionals();
1458 $this->lines[$i] = $line;
1462 $this->db->free($result);
1464 $this->error = $this->db->error();
1475 $this->error =
"Record Not Found";
1478 $this->error = $this->db->error();
1490 public function valid($user, $notrigger = 0)
1492 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
1499 if ((!
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $user->hasRight(
'supplier_proposal',
'creer'))
1500 || (
getDolGlobalString(
'MAIN_USE_ADVANCED_PERMS') && $user->hasRight(
'supplier_proposal',
'validate_advance'))) {
1504 $soc =
new Societe($this->db);
1505 $result = $soc->fetch($this->socid);
1511 dol_syslog(get_class($this).
"::valid checkActiveProductInLines ".$this->error, LOG_INFO);
1515 if (preg_match(
'/^[\(]?PROV/i', $this->
ref) || empty($this->
ref)) {
1516 $num = $this->getNextNumRef($soc);
1522 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"supplier_proposal";
1523 $sql .=
" SET ref = '".$this->db->escape($num).
"',";
1524 $sql .=
" fk_statut = 1, date_valid='".$this->db->idate($now).
"', fk_user_valid=".((int) $user->id);
1525 $sql .=
" WHERE rowid = ".((int) $this->
id).
" AND fk_statut = 0";
1527 dol_syslog(get_class($this).
"::valid", LOG_DEBUG);
1528 $resql = $this->db->query($sql);
1535 if (!$error && !$notrigger) {
1537 $result = $this->call_trigger(
'PROPOSAL_SUPPLIER_VALIDATE', $user);
1545 $this->oldref = $this->ref;
1548 if (preg_match(
'/^[\(]?PROV/i', $this->
ref)) {
1550 $sql =
'UPDATE '.MAIN_DB_PREFIX.
"ecm_files set filename = CONCAT('".$this->db->escape($this->newref).
"', SUBSTR(filename, ".(strlen($this->
ref) + 1).
")), filepath = 'supplier_proposal/".$this->db->escape($this->newref).
"'";
1551 $sql .=
" WHERE filename LIKE '".$this->db->escape($this->
ref).
"%' AND filepath = 'supplier_proposal/".$this->db->escape($this->
ref).
"' and entity = ".$conf->entity;
1552 $resql = $this->db->query($sql);
1555 $this->error = $this->db->lasterror();
1557 $sql =
'UPDATE '.MAIN_DB_PREFIX.
"ecm_files set filepath = 'supplier_proposal/".$this->db->escape($this->newref).
"'";
1558 $sql .=
" WHERE filepath = 'supplier_proposal/".$this->db->escape($this->
ref).
"' and entity = ".$conf->entity;
1559 $resql = $this->db->query($sql);
1562 $this->error = $this->db->lasterror();
1568 $dirsource =
$conf->supplier_proposal->dir_output.
'/'.$oldref;
1569 $dirdest =
$conf->supplier_proposal->dir_output.
'/'.$newref;
1570 if (!$error && file_exists($dirsource)) {
1571 dol_syslog(get_class($this).
"::valid rename dir ".$dirsource.
" into ".$dirdest);
1572 if (@rename($dirsource, $dirdest)) {
1575 $listoffiles =
dol_dir_list(
$conf->supplier_proposal->dir_output.
'/'.$newref,
'files', 1,
'^'.preg_quote($oldref,
'/'));
1576 foreach ($listoffiles as $fileentry) {
1577 $dirsource = $fileentry[
'name'];
1578 $dirdest = preg_replace(
'/^'.preg_quote($oldref,
'/').
'/', $newref, $dirsource);
1579 $dirsource = $fileentry[
'path'].
'/'.$dirsource;
1580 $dirdest = $fileentry[
'path'].
'/'.$dirdest;
1581 @rename($dirsource, $dirdest);
1590 $this->user_validation_id = $user->id;
1591 $this->datev = $now;
1592 $this->date_validation = $now;
1595 $result = $this->
add_contact($user->id,
'SALESREPFOLL',
'internal', 1);
1596 if ($result < 0 && $result != -2) {
1601 $this->db->commit();
1604 $this->db->rollback();
1608 dol_syslog(
"You don't have permission to validate supplier proposal", LOG_WARNING);
1637 if ($user->hasRight(
'supplier_proposal',
'creer')) {
1638 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"supplier_proposal ";
1639 $sql .=
" SET date_livraison = ".(isDolTms($delivery_date) ?
"'".$this->db->idate($delivery_date).
"'" :
'null');
1640 $sql .=
" WHERE rowid = ".((int) $this->
id);
1642 if ($this->db->query($sql)) {
1643 $this->delivery_date = $delivery_date;
1646 $this->error = $this->db->error();
1647 dol_syslog(get_class($this).
"::setDeliveryDate Erreur SQL");
1664 public function reopen($user, $status, $note =
'', $notrigger = 0)
1668 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"supplier_proposal";
1669 $sql .=
" SET fk_statut = ".((int) $status).
",";
1670 if (!empty($note)) {
1671 $sql .=
" note_private = '".$this->db->escape($note).
"',";
1673 $sql .=
" date_cloture = NULL, fk_user_cloture = NULL";
1674 $sql .=
" WHERE rowid = ".((int) $this->
id);
1678 dol_syslog(get_class($this).
"::reopen", LOG_DEBUG);
1679 $resql = $this->db->query($sql);
1682 $this->errors[] =
"Error ".$this->db->lasterror();
1687 $result = $this->call_trigger(
'PROPOSAL_SUPPLIER_REOPEN', $user);
1697 if (!empty($this->errors)) {
1698 foreach ($this->errors as $errmsg) {
1699 dol_syslog(get_class($this).
"::update ".$errmsg, LOG_ERR);
1700 $this->error .= ($this->error ?
', '.$errmsg : $errmsg);
1703 $this->db->rollback();
1706 $this->statut = $status;
1709 $this->db->commit();
1725 global $langs,
$conf;
1735 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"supplier_proposal";
1736 $sql .=
" SET fk_statut = ".((int) $status).
", note_private = '".$this->db->escape($note).
"', date_cloture='".$this->db->idate($now).
"', fk_user_cloture=".((int) $user->id);
1737 $sql .=
" WHERE rowid = ".((int) $this->
id);
1739 $resql = $this->db->query($sql);
1741 $this->statut = $status;
1744 $modelpdf =
getDolGlobalString(
'SUPPLIER_PROPOSAL_ADDON_PDF_ODT_CLOSED', (empty($this->model_pdf) ?
'' : $this->model_pdf));
1745 $triggerName =
'PROPOSAL_SUPPLIER_CLOSE_REFUSED';
1748 $triggerName =
'PROPOSAL_SUPPLIER_CLOSE_SIGNED';
1749 $modelpdf =
getDolGlobalString(
'SUPPLIER_PROPOSAL_ADDON_PDF_ODT_TOBILL', (empty($this->model_pdf) ?
'' : $this->model_pdf));
1756 $triggerName =
'PROPOSAL_SUPPLIER_CLASSIFY_BILLED';
1761 $outputlangs = $langs;
1764 $newlang = (
GETPOST(
'lang_id',
'aZ09') ?
GETPOST(
'lang_id',
'aZ09') : $this->thirdparty->default_lang);
1765 $outputlangs->setDefaultLang($newlang);
1768 $this->
generateDocument($modelpdf, $outputlangs, $hidedetails, $hidedesc, $hideref);
1772 $result = $this->call_trigger($triggerName, $user);
1779 $this->db->commit();
1782 $this->db->rollback();
1786 $this->error = $this->db->lasterror();
1787 $this->errors[] = $this->db->lasterror();
1788 $this->db->rollback();
1801 dol_syslog(get_class($this).
"::updateOrCreatePriceFournisseur", LOG_DEBUG);
1803 foreach ($this->lines as $product) {
1804 if ($product->subprice <= 0) {
1809 $multicurrency_tx = 1;
1810 $fk_multicurrency = 0;
1812 if (empty($this->thirdparty)) {
1816 $ref_fourn = $product->ref_fourn;
1817 if (empty($ref_fourn)) {
1818 $ref_fourn = $product->ref_supplier;
1820 if (
isModEnabled(
"multicurrency") && !empty($product->multicurrency_code)) {
1823 $productsupplier->id = $product->fk_product;
1825 $productsupplier->update_buyprice($product->qty, $product->total_ht, $user,
'HT', $this->thirdparty, 0, $ref_fourn, $product->tva_tx, 0, 0, 0, $product->info_bits, 0,
'', array(),
'', $product->multicurrency_total_ht,
'HT', $multicurrency_tx, $product->multicurrency_code,
'',
'', 0);
1841 $price =
price2num($product->subprice * $product->qty,
'MU');
1842 $unitPrice =
price2num($product->subprice,
'MU');
1844 $sql =
'UPDATE '.MAIN_DB_PREFIX.
'product_fournisseur_price SET '.(!empty($product->ref_fourn) ?
'ref_fourn = "'.$this->db->escape($product->ref_fourn).
'", ' :
'').
' price ='.((
float) $price).
', unitprice ='.((
float) $unitPrice).
' WHERE rowid = '.((
int) $idProductFournPrice);
1846 $resql = $this->db->query($sql);
1848 $this->error = $this->db->error();
1849 $this->db->rollback();
1864 $price =
price2num($product->subprice * $product->qty,
'MU');
1866 $unitPrice =
price2num($product->subprice,
'MU');
1871 "'".$this->db->idate($now).
"'",
1872 (
int) $product->fk_product,
1873 (
int) $this->thirdparty->id,
1874 "'".$this->db->escape($product->ref_fourn).
"'",
1878 (
float) $product->tva_tx,
1882 if (!empty($product->multicurrency_code)) {
1883 include_once DOL_DOCUMENT_ROOT.
'/multicurrency/class/multicurrency.class.php';
1885 $multicurrency->fetch(0, $product->multicurrency_code);
1886 if (!empty($multicurrency->id)) {
1887 $values[] = (int) $multicurrency->id;
1888 $values[] =
"'".$this->db->escape($product->multicurrency_code).
"'";
1889 $values[] = (float) $product->multicurrency_subprice;
1890 $values[] = (float) $product->multicurrency_total_ht;
1891 $values[] = (float) $multicurrency->rate->rate;
1893 for ($i = 0; $i < 5; $i++) {
1900 $sql =
'INSERT INTO '.MAIN_DB_PREFIX.
'product_fournisseur_price ';
1901 $sql .=
'(datec, fk_product, fk_soc, ref_fourn, price, quantity, unitprice, tva_tx, fk_user';
1902 if (
isModEnabled(
"multicurrency") && !empty($product->multicurrency_code)) {
1903 $sql .=
',fk_multicurrency, multicurrency_code, multicurrency_unitprice, multicurrency_price, multicurrency_tx';
1905 $sql .=
') VALUES ('.implode(
',', $values).
')';
1907 $resql = $this->db->query($sql);
1909 $this->error = $this->db->error();
1910 $this->db->rollback();
1928 if ($this->
status == self::STATUS_DRAFT) {
1929 dol_syslog(get_class($this).
"::setDraft already draft status", LOG_WARNING);
1933 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"supplier_proposal";
1934 $sql .=
" SET fk_statut = ".self::STATUS_DRAFT;
1935 $sql .=
" WHERE rowid = ".((int) $this->
id);
1937 if ($this->db->query($sql)) {
1939 $this->oldcopy = clone $this;
1944 $result = $this->call_trigger(
'PROPOSAL_SUPPLIER_UNVALIDATE', $user);
1953 $this->db->commit();
1956 $this->db->rollback();
1979 public function liste_array($shortlist = 0, $draft = 0, $notcurrentuser = 0, $socid = 0, $limit = 0, $offset = 0, $sortfield =
'p.datec', $sortorder =
'DESC')
1987 if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
1988 $search_sale = $user->id;
1991 $sql =
"SELECT s.rowid, s.nom as name, s.client,";
1992 $sql .=
" p.rowid as supplier_proposalid, p.fk_statut, p.total_ht, p.ref, p.remise, ";
1993 $sql .=
" p.datep as dp, p.fin_validite as datelimite";
1994 $sql .=
" FROM ".MAIN_DB_PREFIX.
"societe as s, ".MAIN_DB_PREFIX.
"supplier_proposal as p, ".MAIN_DB_PREFIX.
"c_propalst as c";
1995 $sql .=
" WHERE p.entity IN (".getEntity(
'supplier_proposal').
")";
1996 $sql .=
" AND p.fk_soc = s.rowid";
1997 $sql .=
" AND p.fk_statut = c.id";
1999 $sql .=
" AND s.rowid = ".((int) $socid);
2002 $sql .=
" AND p.fk_statut = 0";
2004 if ($notcurrentuser > 0) {
2005 $sql .=
" AND p.fk_user_author <> ".((int) $user->id);
2008 if ($search_sale && $search_sale !=
'-1') {
2009 if ($search_sale == -2) {
2010 $sql .=
" AND NOT EXISTS (SELECT sc.fk_soc FROM ".MAIN_DB_PREFIX.
"societe_commerciaux as sc WHERE sc.fk_soc = p.fk_soc)";
2011 } elseif ($search_sale > 0) {
2012 $sql .=
" AND EXISTS (SELECT sc.fk_soc FROM ".MAIN_DB_PREFIX.
"societe_commerciaux as sc WHERE sc.fk_soc = p.fk_soc AND sc.fk_user = ".((int) $search_sale).
")";
2015 $sql .= $this->db->order($sortfield, $sortorder);
2016 $sql .= $this->db->plimit($limit, $offset);
2018 $result = $this->db->query($sql);
2020 $num = $this->db->num_rows($result);
2024 $obj = $this->db->fetch_object($result);
2026 if ($shortlist == 1) {
2027 $ga[$obj->supplier_proposalid] = $obj->ref;
2028 } elseif ($shortlist == 2) {
2029 $ga[$obj->supplier_proposalid] = $obj->ref.
' ('.$obj->name.
')';
2031 $ga[$i][
'id'] = $obj->supplier_proposalid;
2032 $ga[$i][
'ref'] = $obj->ref;
2033 $ga[$i][
'name'] = $obj->name;
2053 public function delete($user, $notrigger = 0)
2056 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
2064 $result = $this->call_trigger(
'PROPOSAL_SUPPLIER_DELETE', $user);
2072 $main = MAIN_DB_PREFIX.
'supplier_proposaldet';
2073 $ef = $main.
"_extrafields";
2074 $sqlef =
"DELETE FROM $ef WHERE fk_object IN (SELECT rowid FROM $main WHERE fk_supplier_proposal = ".((int) $this->
id).
")";
2075 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"supplier_proposaldet WHERE fk_supplier_proposal = ".((int) $this->
id);
2076 if ($this->db->query($sql)) {
2077 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"supplier_proposal WHERE rowid = ".((int) $this->
id);
2078 if ($this->db->query($sqlef) && $this->db->query($sql)) {
2092 if ($conf->supplier_proposal->dir_output && !empty($this->
ref)) {
2093 $dir =
$conf->supplier_proposal->dir_output.
"/".$ref;
2094 $file = $dir.
"/".$ref.
".pdf";
2095 if (file_exists($file)) {
2099 $this->error =
'ErrorFailToDeleteFile';
2100 $this->errors = array(
'ErrorFailToDeleteFile');
2101 $this->db->rollback();
2105 if (file_exists($dir)) {
2108 $this->error =
'ErrorFailToDeleteDir';
2109 $this->errors = array(
'ErrorFailToDeleteDir');
2110 $this->db->rollback();
2123 dol_syslog(get_class($this).
"::delete erreur ".$errorflag.
" ".$this->error, LOG_ERR);
2128 dol_syslog(get_class($this).
"::delete ".$this->
id.
" by ".$user->id, LOG_DEBUG);
2129 $this->db->commit();
2132 $this->error = $this->db->lasterror();
2133 $this->db->rollback();
2137 $this->error = $this->db->lasterror();
2138 $this->db->rollback();
2142 $this->error = $this->db->lasterror();
2143 $this->db->rollback();
2147 $this->db->rollback();
2160 $sql =
"SELECT c.rowid, GREATEST(c.tms, cef.tms) as date_modification,";
2161 $sql .=
" c.datec as date_creation, c.date_valid as date_validation, c.date_cloture as date_closure,";
2162 $sql .=
" c.fk_user_author, c.fk_user_modif, c.fk_user_valid, c.fk_user_cloture";
2163 $sql .=
" FROM ".MAIN_DB_PREFIX.
"supplier_proposal as c";
2164 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"supplier_proposal_extrafields as cef ON cef.fk_object=c.rowid";
2165 $sql .=
" WHERE c.rowid = ".((int) $id);
2167 $result = $this->db->query($sql);
2170 if ($this->db->num_rows($result)) {
2171 $obj = $this->db->fetch_object($result);
2173 $this->
id = $obj->rowid;
2175 $this->date_creation = $this->db->jdate($obj->date_creation);
2176 $this->date_modification = empty($obj->date_modification) ?
'' : $this->db->jdate($obj->date_modification);
2177 $this->date_validation = $this->db->jdate($obj->date_validation);
2178 $this->date_cloture = $this->db->jdate($obj->date_closure);
2180 $this->user_creation_id = $obj->fk_user_author;
2181 $this->user_modification_id = $obj->fk_user_modif;
2182 $this->user_validation_id = $obj->fk_user_valid;
2183 $this->user_closing_id = $obj->fk_user_cloture;
2185 $this->db->free($result);
2216 if (empty($this->labelStatus) || empty($this->labelStatusShort)) {
2218 $langs->load(
"supplier_proposal");
2219 $this->labelStatus[
self::STATUS_DRAFT] = $langs->transnoentitiesnoconv(
"SupplierProposalStatusDraft");
2220 $this->labelStatus[
self::STATUS_VALIDATED] = $langs->transnoentitiesnoconv(
"SupplierProposalStatusValidated");
2221 $this->labelStatus[
self::STATUS_SIGNED] = $langs->transnoentitiesnoconv(
"SupplierProposalStatusSigned");
2222 $this->labelStatus[
self::STATUS_NOTSIGNED] = $langs->transnoentitiesnoconv(
"SupplierProposalStatusNotSigned");
2223 $this->labelStatus[
self::STATUS_CLOSE] = $langs->transnoentitiesnoconv(
"SupplierProposalStatusClosed");
2224 $this->labelStatusShort[
self::STATUS_DRAFT] = $langs->transnoentitiesnoconv(
"SupplierProposalStatusDraftShort");
2225 $this->labelStatusShort[
self::STATUS_VALIDATED] = $langs->transnoentitiesnoconv(
"SupplierProposalStatusValidatedShort");
2226 $this->labelStatusShort[
self::STATUS_SIGNED] = $langs->transnoentitiesnoconv(
"SupplierProposalStatusSignedShort");
2227 $this->labelStatusShort[
self::STATUS_NOTSIGNED] = $langs->transnoentitiesnoconv(
"SupplierProposalStatusNotSignedShort");
2228 $this->labelStatusShort[
self::STATUS_CLOSE] = $langs->transnoentitiesnoconv(
"SupplierProposalStatusClosedShort");
2232 if ($status == self::STATUS_DRAFT) {
2233 $statusnew =
'status0';
2234 } elseif ($status == self::STATUS_VALIDATED) {
2235 $statusnew =
'status1';
2236 } elseif ($status == self::STATUS_SIGNED) {
2237 $statusnew =
'status4';
2238 } elseif ($status == self::STATUS_NOTSIGNED) {
2239 $statusnew =
'status9';
2240 } elseif ($status == self::STATUS_CLOSE) {
2241 $statusnew =
'status6';
2244 return dolGetStatus($this->labelStatus[$status], $this->labelStatusShort[$status],
'', $statusnew, $mode);
2259 global
$conf, $langs;
2265 $sql =
"SELECT p.rowid, p.ref, p.datec as datec, p.date_cloture as datefin";
2266 $sql .=
" FROM ".MAIN_DB_PREFIX.
"supplier_proposal as p";
2267 if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
2268 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe_commerciaux as sc ON p.fk_soc = sc.fk_soc";
2269 $sql .=
" WHERE sc.fk_user = ".((int) $user->id);
2272 $sql .= $clause.
" p.entity IN (".
getEntity(
'supplier_proposal').
")";
2273 if ($mode ==
'opened') {
2274 $sql .=
" AND p.fk_statut = 1";
2276 if ($mode ==
'signed') {
2277 $sql .=
" AND p.fk_statut = 2";
2280 $sql .=
" AND p.fk_soc = ".((int) $user->socid);
2283 $resql = $this->db->query($sql);
2285 $label = $labelShort =
'';
2288 if ($mode ==
'opened') {
2289 $delay_warning = !empty(
$conf->supplier_proposal->cloture->warning_delay) ?
$conf->supplier_proposal->cloture->warning_delay : 0;
2291 $label = $langs->trans(
"SupplierProposalsToClose");
2292 $labelShort = $langs->trans(
"ToAcceptRefuse");
2294 if ($mode ==
'signed') {
2295 $delay_warning = !empty(
$conf->supplier_proposal->facturation->warning_delay) ?
$conf->supplier_proposal->facturation->warning_delay : 0;
2297 $label = $langs->trans(
"SupplierProposalsToProcess");
2298 $labelShort = $langs->trans(
"ToClose");
2302 $response->warning_delay = $delay_warning / 60 / 60 / 24;
2303 $response->label = $label;
2304 $response->labelShort = $labelShort;
2305 $response->url = DOL_URL_ROOT.
'/supplier_proposal/list.php?search_status='.$status;
2309 while ($obj = $this->db->fetch_object($resql)) {
2310 $response->nbtodo++;
2311 if ($mode ==
'opened') {
2312 $datelimit = $this->db->jdate($obj->datefin);
2313 if ($datelimit < ($now - $delay_warning)) {
2314 $response->nbtodolate++;
2322 $this->error = $this->db->lasterror();
2338 global
$conf, $langs;
2343 $sql =
"SELECT rowid";
2344 $sql .=
" FROM ".MAIN_DB_PREFIX.
"product";
2345 $sql .=
" WHERE entity IN (".getEntity(
'product').
")";
2346 if (array_key_exists(
'tobuy', $param)) {
2347 $sql .=
" AND tobuy = ".((int) $param[
'tobuy']);
2349 $sql .= $this->db->plimit(100);
2351 $resql = $this->db->query($sql);
2353 $num_prods = $this->db->num_rows($resql);
2355 while ($i < $num_prods) {
2357 $row = $this->db->fetch_row($resql);
2358 $prodids[$i] = $row[0];
2364 $this->
ref =
'SPECIMEN';
2365 $this->ref_supplier =
'NEMICEPS';
2366 $this->specimen = 1;
2368 $this->
date = time();
2369 $this->cond_reglement_id = 1;
2370 $this->cond_reglement_code =
'RECEP';
2371 $this->mode_reglement_id = 7;
2372 $this->mode_reglement_code =
'CHQ';
2373 $this->note_public =
'This is a comment (public)';
2374 $this->note_private =
'This is a comment (private)';
2376 $this->multicurrency_tx = 1;
2382 while ($xnbp < $nbp) {
2384 $line->desc = $langs->trans(
"Description").
" ".$xnbp;
2386 $line->subprice = 100;
2387 $line->tva_tx = 19.6;
2388 $line->localtax1_tx = 0;
2389 $line->localtax2_tx = 0;
2391 $line->total_ht = 50;
2392 $line->total_ttc = 59.8;
2393 $line->total_tva = 9.8;
2394 $line->remise_percent = 50;
2396 $line->total_ht = 100;
2397 $line->total_ttc = 119.6;
2398 $line->total_tva = 19.6;
2399 $line->remise_percent = 00;
2402 if ($num_prods > 0) {
2403 $prodid = mt_rand(1, $num_prods);
2404 $line->fk_product = $prodids[$prodid];
2407 $this->lines[$xnbp] = $line;
2409 $this->total_ht += $line->total_ht;
2410 $this->total_tva += $line->total_tva;
2411 $this->total_ttc += $line->total_ttc;
2428 $this->nb = array();
2431 $sql =
"SELECT count(p.rowid) as nb";
2432 $sql .=
" FROM ".MAIN_DB_PREFIX.
"supplier_proposal as p";
2433 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe as s ON p.fk_soc = s.rowid";
2434 if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
2435 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe_commerciaux as sc ON s.rowid = sc.fk_soc";
2436 $sql .=
" WHERE sc.fk_user = ".((int) $user->id);
2439 $sql .=
" ".$clause.
" p.entity IN (".
getEntity(
'supplier_proposal').
")";
2441 $resql = $this->db->query($sql);
2444 while ($obj = $this->db->fetch_object($resql)) {
2445 $this->nb[
"supplier_proposals"] = $obj->nb;
2447 $this->db->free($resql);
2451 $this->error = $this->db->lasterror();
2464 public function getNextNumRef($soc)
2466 global
$conf, $db, $langs;
2467 $langs->load(
"supplier_proposal");
2476 $dirmodels = array_merge(array(
'/'), (array)
$conf->modules_parts[
'models']);
2477 foreach ($dirmodels as $reldir) {
2478 $dir =
dol_buildpath($reldir.
"core/modules/supplier_proposal/");
2481 $mybool = ((bool) @include_once $dir.$file) || $mybool;
2489 $obj =
new $classname();
2490 '@phan-var-force ModeleNumRefSupplierProposal $obj';
2493 $numref = $obj->getNextValue($soc, $this);
2495 if ($numref !=
"") {
2498 $this->error = $obj->error;
2502 $langs->load(
"errors");
2503 print $langs->trans(
"Error").
" ".$langs->trans(
"ErrorModuleSetupNotComplete", $langs->transnoentitiesnoconv(
"SupplierProposal"));
2516 global
$conf, $langs;
2518 $langs->load(
'supplier_proposal');
2521 return [
'optimize' => $langs->trans(
"ShowSupplierProposal")];
2527 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"SupplierProposal").
'</u>';
2528 if (isset($this->
status)) {
2529 $datas[
'picto'] .=
' '.$this->getLibStatut(5);
2531 if (!empty($this->
ref)) {
2532 $datas[
'ref'] =
'<br><b>'.$langs->trans(
'Ref').
':</b> '.$this->ref;
2534 if (!empty($this->ref_fourn)) {
2535 $datas[
'ref_supplier'] =
'<br><b>'.$langs->trans(
'RefSupplier').
':</b> '.$this->ref_fourn;
2537 if (!empty($this->total_ht)) {
2538 $datas[
'amount_ht'] =
'<br><b>'.$langs->trans(
'AmountHT').
':</b> '.
price($this->total_ht, 0, $langs, 0, -1, -1,
getDolCurrency());
2540 if (!empty($this->total_tva)) {
2541 $datas[
'amount_vat'] =
'<br><b>'.$langs->trans(
'VAT').
':</b> '.
price($this->total_tva, 0, $langs, 0, -1, -1,
getDolCurrency());
2543 if (!empty($this->total_ttc)) {
2544 $datas[
'amount_ttc'] =
'<br><b>'.$langs->trans(
'AmountTTC').
':</b> '.
price($this->total_ttc, 0, $langs, 0, -1, -1,
getDolCurrency());
2561 public function getNomUrl($withpicto = 0, $option =
'', $get_params =
'', $notooltip = 0, $save_lastsearch_value = -1, $addlinktonotes = 0)
2563 global $langs,
$conf, $user, $hookmanager;
2565 if (!empty(
$conf->dol_no_mouse_hover)) {
2573 'objecttype' => $this->element,
2574 'option' => $option,
2576 $classfortooltip =
'classfortooltip';
2579 $classfortooltip =
'classforajaxtooltip';
2580 $dataparams =
' data-params="'.dol_escape_htmltag(json_encode($params)).
'"';
2586 if ($option ==
'') {
2587 $url = DOL_URL_ROOT.
'/supplier_proposal/card.php?id='.$this->
id.$get_params;
2589 if ($option ==
'document') {
2590 $url = DOL_URL_ROOT.
'/supplier_proposal/document.php?id='.$this->
id.$get_params;
2593 if ($option !==
'nolink') {
2595 $add_save_lastsearch_values = ($save_lastsearch_value == 1 ? 1 : 0);
2596 if ($save_lastsearch_value == -1 && isset($_SERVER[
"PHP_SELF"]) && preg_match(
'/list\.php/', $_SERVER[
"PHP_SELF"])) {
2597 $add_save_lastsearch_values = 1;
2599 if ($add_save_lastsearch_values) {
2600 $url .=
'&save_lastsearch_values=1';
2605 if (empty($notooltip) && $user->hasRight(
'propal',
'lire')) {
2607 $label = $langs->trans(
"ShowSupplierProposal");
2608 $linkclose .=
' alt="'.dolPrintHTMLForAttribute($label).
'"';
2610 $linkclose .= ($label ?
' title="'.dolPrintHTMLForAttribute($label).
'"' :
' title="tocomplete"');
2611 $linkclose .= $dataparams.
' class="'.$classfortooltip.
'"';
2614 $linkstart =
'<a href="'.$url.
'"';
2615 $linkstart .= $linkclose.
'>';
2618 $result .= $linkstart;
2620 $result .=
img_object(($notooltip ?
'' : $label), ($this->picto ? $this->picto :
'generic'), (($withpicto != 2) ?
'class="paddingright"' :
''), 0, 0, $notooltip ? 0 : 1);
2622 if ($withpicto != 2) {
2623 $result .= $this->ref;
2625 $result .= $linkend;
2627 if ($addlinktonotes) {
2628 $txttoshow = ($user->socid > 0 ? $this->note_public : $this->note_private);
2631 $result .=
' <span class="note inline-block">';
2632 $result .=
'<a href="'.DOL_URL_ROOT.
'/supplier_proposal/note.php?id='.$this->
id.
'" class="classfortooltip" title="'.
dol_escape_htmltag($notetoshow).
'">';
2637 $result .=
'</span>';
2641 $hookmanager->initHooks(array($this->element .
'dao'));
2642 $parameters = array(
'id' => $this->
id,
'getnomurl' => &$result);
2643 $reshook = $hookmanager->executeHooks(
'getNomUrl', $parameters, $this, $action);
2645 $result = $hookmanager->resPrint;
2647 $result .= $hookmanager->resPrint;
2661 $sql =
'SELECT pt.rowid, pt.label as custom_label, pt.description, pt.fk_product, pt.fk_remise_except,';
2662 $sql .=
' pt.qty, pt.tva_tx, pt.vat_src_code, pt.remise_percent, pt.subprice, pt.info_bits,';
2663 $sql .=
' pt.total_ht, pt.total_tva, pt.total_ttc, pt.fk_product_fournisseur_price as fk_fournprice, pt.buy_price_ht as pa_ht, pt.special_code, pt.localtax1_tx, pt.localtax2_tx,';
2664 $sql .=
' pt.product_type, pt.rang, pt.fk_parent_line, pt.extraparams,';
2665 $sql .=
' p.label as product_label, p.ref, p.fk_product_type, p.rowid as prodid,';
2666 $sql .=
' p.description as product_desc, pt.ref_fourn as ref_supplier,';
2667 $sql .=
' pt.fk_multicurrency, pt.multicurrency_code, pt.multicurrency_subprice, pt.multicurrency_total_ht, pt.multicurrency_total_tva, pt.multicurrency_total_ttc, pt.fk_unit';
2668 $sql .=
' FROM '.MAIN_DB_PREFIX.
'supplier_proposaldet as pt';
2669 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'product as p ON pt.fk_product=p.rowid';
2670 $sql .=
' WHERE pt.fk_supplier_proposal = '.((int) $this->
id);
2671 $sql .=
' ORDER BY pt.rang ASC, pt.rowid';
2673 dol_syslog(get_class($this).
'::getLinesArray', LOG_DEBUG);
2674 $resql = $this->db->query($sql);
2676 $num = $this->db->num_rows($resql);
2680 $obj = $this->db->fetch_object($resql);
2683 $this->lines[$i]->id = $obj->rowid;
2684 $this->lines[$i]->rowid = $obj->rowid;
2685 $this->lines[$i]->label = $obj->custom_label;
2686 $this->lines[$i]->description = $obj->description;
2687 $this->lines[$i]->desc = $obj->description;
2688 $this->lines[$i]->fk_product = $obj->fk_product;
2689 $this->lines[$i]->ref = $obj->ref;
2690 $this->lines[$i]->product_label = $obj->product_label;
2691 $this->lines[$i]->product_desc = $obj->product_desc;
2692 $this->lines[$i]->fk_product_type = $obj->fk_product_type;
2693 $this->lines[$i]->product_type = $obj->product_type;
2694 $this->lines[$i]->qty = $obj->qty;
2695 $this->lines[$i]->subprice = $obj->subprice;
2696 $this->lines[$i]->fk_remise_except = $obj->fk_remise_except;
2697 $this->lines[$i]->remise_percent = $obj->remise_percent;
2698 $this->lines[$i]->tva_tx = $obj->tva_tx;
2699 $this->lines[$i]->vat_src_code = $obj->vat_src_code;
2700 $this->lines[$i]->info_bits = $obj->info_bits;
2701 $this->lines[$i]->total_ht = $obj->total_ht;
2702 $this->lines[$i]->total_tva = $obj->total_tva;
2703 $this->lines[$i]->total_ttc = $obj->total_ttc;
2704 $this->lines[$i]->fk_fournprice = $obj->fk_fournprice;
2705 $marginInfos =
getMarginInfos($obj->subprice, $obj->remise_percent, $obj->tva_tx, $obj->localtax1_tx, $obj->localtax2_tx, $this->lines[$i]->fk_fournprice, $obj->pa_ht);
2706 $this->lines[$i]->pa_ht = $marginInfos[0];
2707 $this->lines[$i]->marge_tx = $marginInfos[1];
2708 $this->lines[$i]->marque_tx = $marginInfos[2];
2709 $this->lines[$i]->fk_parent_line = $obj->fk_parent_line;
2710 $this->lines[$i]->special_code = $obj->special_code;
2711 $this->lines[$i]->rang = $obj->rang;
2713 $this->lines[$i]->ref_fourn = $obj->ref_supplier;
2714 $this->lines[$i]->ref_supplier = $obj->ref_supplier;
2717 $this->lines[$i]->fk_multicurrency = $obj->fk_multicurrency;
2718 $this->lines[$i]->multicurrency_code = $obj->multicurrency_code;
2719 $this->lines[$i]->multicurrency_subprice = $obj->multicurrency_subprice;
2720 $this->lines[$i]->multicurrency_total_ht = $obj->multicurrency_total_ht;
2721 $this->lines[$i]->multicurrency_total_tva = $obj->multicurrency_total_tva;
2722 $this->lines[$i]->multicurrency_total_ttc = $obj->multicurrency_total_ttc;
2723 $this->lines[$i]->fk_unit = $obj->fk_unit;
2724 $this->lines[$i]->extraparams = !empty($obj->extraparams) ? (array) json_decode($obj->extraparams,
true) : array();
2726 $this->lines[$i]->fetch_optionals();
2730 $this->db->free($resql);
2734 $this->error = $this->db->error();
2750 public function generateDocument($modele, $outputlangs, $hidedetails = 0, $hidedesc = 0, $hideref = 0, $moreparams =
null)
2754 $langs->load(
"supplier_proposal");
2755 $outputlangs->load(
"products");
2760 if ($this->model_pdf) {
2761 $modele = $this->model_pdf;
2767 if (empty($modele)) {
2771 $modelpath =
"core/modules/supplier_proposal/doc/";
2773 return $this->
commonGenerateDocument($modelpath, $modele, $outputlangs, $hidedetails, $hidedesc, $hideref, $moreparams);
2805 'supplier_proposaldet'
2823 $selected = (empty($arraydata[
'selected']) ? 0 : $arraydata[
'selected']);
2825 $return =
'<div class="box-flex-item box-flex-grow-zero">';
2826 $return .=
'<div class="info-box info-box-sm">';
2827 $return .=
'<span class="info-box-icon bg-infobox-action">';
2830 $return .=
'</span>';
2831 $return .=
'<div class="info-box-content">';
2832 $return .=
'<span class="info-box-ref inline-block tdoverflowmax150 valignmiddle">'.(method_exists($this,
'getNomUrl') ? $this->
getNomUrl() : $this->ref).
'</span>';
2833 if ($selected >= 0) {
2834 $return .=
'<input id="cb'.$this->id.
'" class="flat checkforselect fright" type="checkbox" name="toselect[]" value="'.$this->
id.
'"'.($selected ?
' checked="checked"' :
'').
'>';
2836 if (property_exists($this,
'socid')) {
2837 $return .=
'<span class="info-box-ref"> | '.$this->socid.
'</span>';
2839 if (property_exists($this,
'delivery_date')) {
2840 $return .=
'<br><span class="opacitymedium">'.$langs->trans(
"DateEnd").
'</span> : <span class="info-box-label">'.
dol_print_date($this->delivery_date).
'</span>';
2842 if (property_exists($this,
'total_ttc')) {
2843 $return .=
'<br><span class="opacitymedium" >'.$langs->trans(
"AmountHT").
' : </span><span class="info-box-label amount">'.
price($this->total_ttc).
'</span>';
2845 if (method_exists($this,
'getLibStatut')) {
2846 $return .=
'<br><div class="info-box-status">'.$this->getLibStatut(3).
'</div>';
2848 $return .=
'</div>';
2849 $return .=
'</div>';
2850 $return .=
'</div>';
2866 require_once DOL_DOCUMENT_ROOT.
'/categories/class/categorie.class.php';
2867 return parent::setCategoriesCommon($categories, Categorie::TYPE_SUPPLIER_PROPOSAL);
2890 public $element =
'supplier_proposaldet';
2895 public $table_element =
'supplier_proposaldet';
2920 public $fk_supplier_proposal;
2925 public $fk_parent_line;
2942 public $fk_product_type;
2961 public $vat_src_code;
2966 public $remise_percent;
2971 public $fk_remise_except;
2981 public $fk_fournprice;
2999 public $special_code;
3007 public $info_bits = 0;
3045 public $product_ref;
3058 public $product_label;
3070 public $product_desc;
3075 public $localtax1_tx;
3079 public $localtax2_tx;
3083 public $localtax1_type;
3087 public $localtax2_type;
3091 public $total_localtax1;
3095 public $total_localtax2;
3100 public $skip_update_total;
3109 public $ref_supplier;
3115 public $fk_multicurrency;
3120 public $multicurrency_code;
3124 public $multicurrency_subprice;
3128 public $multicurrency_total_ht;
3132 public $multicurrency_total_tva;
3136 public $multicurrency_total_ttc;
3156 $sql =
'SELECT pd.rowid, pd.fk_supplier_proposal, pd.fk_parent_line, pd.fk_product, pd.label as custom_label, pd.description, pd.price, pd.qty, pd.tva_tx,';
3157 $sql .=
' pd.date_start, pd.date_end,';
3158 $sql .=
' pd.remise, pd.remise_percent, pd.fk_remise_except, pd.subprice, pd.subprice_ttc,';
3159 $sql .=
' pd.info_bits, pd.total_ht, pd.total_tva, pd.total_ttc, pd.fk_product_fournisseur_price as fk_fournprice, pd.buy_price_ht as pa_ht, pd.special_code, pd.rang,';
3160 $sql .=
' pd.localtax1_tx, pd.localtax2_tx, pd.total_localtax1, pd.total_localtax2,';
3161 $sql .=
' p.ref as product_ref, p.label as product_label, p.description as product_desc,';
3162 $sql .=
' pd.product_type, pd.ref_fourn as ref_produit_fourn, pd.extraparams,';
3163 $sql .=
' pd.fk_multicurrency, pd.multicurrency_code, pd.multicurrency_subprice, pd.multicurrency_subprice_ttc, pd.multicurrency_total_ht, pd.multicurrency_total_tva, pd.multicurrency_total_ttc, pd.fk_unit';
3164 $sql .=
' FROM '.MAIN_DB_PREFIX.
'supplier_proposaldet as pd';
3165 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'product as p ON pd.fk_product = p.rowid';
3166 $sql .=
' WHERE pd.rowid = '.((int) $rowid);
3168 $result = $this->db->query($sql);
3170 if ($objp = $this->db->fetch_object($result)) {
3171 $this->
id = $objp->rowid;
3172 $this->fk_supplier_proposal = $objp->fk_supplier_proposal;
3173 $this->fk_parent_line = $objp->fk_parent_line;
3174 $this->label = $objp->custom_label;
3175 $this->desc = $objp->description;
3176 $this->qty = $objp->qty;
3178 $this->subprice = $objp->subprice;
3179 $this->subprice_ttc = $objp->subprice_ttc;
3181 $this->tva_tx = $objp->tva_tx;
3182 $this->remise_percent = $objp->remise_percent;
3183 $this->fk_remise_except = $objp->fk_remise_except;
3184 $this->fk_product = $objp->fk_product;
3185 $this->info_bits = $objp->info_bits;
3186 $this->date_start = $this->db->jdate($objp->date_start);
3187 $this->date_end = $this->db->jdate($objp->date_end);
3189 $this->total_ht = $objp->total_ht;
3190 $this->total_tva = $objp->total_tva;
3191 $this->total_ttc = $objp->total_ttc;
3193 $this->fk_fournprice = $objp->fk_fournprice;
3195 $marginInfos =
getMarginInfos($objp->subprice, $objp->remise_percent, $objp->tva_tx, $objp->localtax1_tx, $objp->localtax2_tx, $this->fk_fournprice, $objp->pa_ht);
3196 $this->pa_ht = $marginInfos[0];
3197 $this->marge_tx = $marginInfos[1];
3198 $this->marque_tx = $marginInfos[2];
3200 $this->special_code = $objp->special_code;
3201 $this->product_type = $objp->product_type;
3202 $this->rang = $objp->rang;
3204 $this->product_ref = $objp->product_ref;
3205 $this->product_label = $objp->product_label;
3206 $this->product_desc = $objp->product_desc;
3208 $this->ref_fourn = $objp->ref_produit_fourn;
3210 $this->extraparams = !empty($objp->extraparams) ? (array) json_decode($objp->extraparams,
true) : array();
3213 $this->fk_multicurrency = $objp->fk_multicurrency;
3214 $this->multicurrency_code = $objp->multicurrency_code;
3215 $this->multicurrency_subprice = $objp->multicurrency_subprice;
3216 $this->multicurrency_subprice_ttc = $objp->multicurrency_subprice_ttc;
3217 $this->multicurrency_total_ht = $objp->multicurrency_total_ht;
3218 $this->multicurrency_total_tva = $objp->multicurrency_total_tva;
3219 $this->multicurrency_total_ttc = $objp->multicurrency_total_ttc;
3220 $this->fk_unit = $objp->fk_unit;
3222 $this->db->free($result);
3244 dol_syslog(get_class($this).
"::insert rang=".$this->rang);
3247 if (empty($this->tva_tx)) {
3250 if (empty($this->vat_src_code)) {
3251 $this->vat_src_code =
'';
3253 if (empty($this->localtax1_tx)) {
3254 $this->localtax1_tx = 0;
3256 if (empty($this->localtax2_tx)) {
3257 $this->localtax2_tx = 0;
3259 if (empty($this->localtax1_type)) {
3260 $this->localtax1_type =
'';
3262 if (empty($this->localtax2_type)) {
3263 $this->localtax2_type =
'';
3265 if (empty($this->total_localtax1)) {
3266 $this->total_localtax1 = 0;
3268 if (empty($this->total_localtax2)) {
3269 $this->total_localtax2 = 0;
3271 if (empty($this->rang)) {
3274 if (empty($this->remise_percent)) {
3275 $this->remise_percent = 0;
3277 if (empty($this->info_bits)) {
3278 $this->info_bits = 0;
3280 if (empty($this->special_code)) {
3281 $this->special_code = 0;
3283 if (empty($this->fk_parent_line)) {
3284 $this->fk_parent_line = 0;
3286 if (empty($this->fk_fournprice)) {
3287 $this->fk_fournprice = 0;
3289 if (empty($this->fk_unit)) {
3292 if (empty($this->subprice)) {
3293 $this->subprice = 0;
3296 if (empty($this->pa_ht)) {
3301 if ($this->pa_ht == 0) {
3302 $result = $this->
defineBuyPrice($this->subprice, $this->remise_percent, $this->fk_product);
3306 $this->pa_ht = $result;
3311 if ($this->product_type < 0) {
3318 $sql =
'INSERT INTO '.MAIN_DB_PREFIX.
'supplier_proposaldet';
3319 $sql .=
' (fk_supplier_proposal, fk_parent_line, label, description, fk_product, product_type,';
3320 $sql .=
' date_start, date_end,';
3321 $sql .=
' fk_remise_except, qty, tva_tx, vat_src_code, localtax1_tx, localtax2_tx, localtax1_type, localtax2_type,';
3322 $sql .=
' subprice, subprice_ttc, remise_percent, ';
3323 $sql .=
' info_bits, ';
3324 $sql .=
' total_ht, total_tva, total_localtax1, total_localtax2, total_ttc, fk_product_fournisseur_price, buy_price_ht, special_code, rang,';
3325 $sql .=
' ref_fourn,';
3326 $sql .=
' fk_multicurrency, multicurrency_code, multicurrency_subprice, multicurrency_subprice_ttc, multicurrency_total_ht, multicurrency_total_tva, multicurrency_total_ttc, fk_unit)';
3327 $sql .=
" VALUES (".$this->fk_supplier_proposal.
",";
3328 $sql .=
" ".($this->fk_parent_line > 0 ? ((int) $this->fk_parent_line) :
"null").
",";
3329 $sql .=
" ".(!empty($this->label) ?
"'".$this->db->escape($this->label).
"'" :
"null").
",";
3330 $sql .=
" '".$this->db->escape($this->desc).
"',";
3331 $sql .=
" ".($this->fk_product ? ((int) $this->fk_product) :
"null").
",";
3332 $sql .=
" ".((int) $this->product_type).
",";
3333 $sql .=
" ".($this->date_start ?
"'".$this->db->idate($this->date_start).
"'" :
"null").
",";
3334 $sql .=
" ".($this->date_end ?
"'".$this->db->idate($this->date_end).
"'" :
"null").
",";
3335 $sql .=
" ".($this->fk_remise_except ? ((int) $this->fk_remise_except) :
"null").
",";
3336 $sql .=
" ".(float)
price2num($this->qty,
'MS').
",";
3337 $sql .=
" ".(float)
price2num($this->tva_tx).
",";
3338 $sql .=
" '".$this->db->escape($this->vat_src_code).
"',";
3339 $sql .=
" ".(float)
price2num($this->localtax1_tx).
",";
3340 $sql .=
" ".(float)
price2num($this->localtax2_tx).
",";
3341 $sql .=
" '".$this->db->escape($this->localtax1_type).
"',";
3342 $sql .=
" '".$this->db->escape($this->localtax2_type).
"',";
3343 $sql .=
" ".(float)
price2num($this->subprice,
'MU') .
",";
3344 $sql .=
" ".(float)
price2num($this->subprice_ttc,
'MU') .
",";
3345 $sql .=
" ".((float) $this->remise_percent).
",";
3346 $sql .=
" ".(isset($this->info_bits) ? ((int) $this->info_bits) :
"null").
",";
3347 $sql .=
" ".(float)
price2num($this->total_ht,
'MT').
",";
3348 $sql .=
" ".(float)
price2num($this->total_tva,
'MT').
",";
3349 $sql .=
" ".(float)
price2num($this->total_localtax1,
'MT').
",";
3350 $sql .=
" ".(float)
price2num($this->total_localtax2,
'MT').
",";
3351 $sql .=
" ".(float)
price2num($this->total_ttc,
'MT').
",";
3352 $sql .=
" ".(!empty($this->fk_fournprice) ? ((int) $this->fk_fournprice) :
"null").
",";
3353 $sql .=
" ".(isset($this->pa_ht) ? (float)
price2num($this->pa_ht,
'MU') :
"null").
",";
3354 $sql .=
' '.((int) $this->special_code).
',';
3355 $sql .=
' '.((int) $this->rang).
',';
3356 $sql .=
" '".$this->db->escape($this->ref_fourn).
"'";
3357 $sql .=
", ".($this->fk_multicurrency > 0 ? ((int) $this->fk_multicurrency) :
'null');
3358 $sql .=
", '".$this->db->escape($this->multicurrency_code).
"'";
3359 $sql .=
", ".(float)
price2num($this->multicurrency_subprice,
'CU');
3360 $sql .=
", ".(float)
price2num($this->multicurrency_subprice_ttc,
'CU');
3361 $sql .=
", ".(float)
price2num($this->multicurrency_total_ht,
'CT');
3362 $sql .=
", ".(float)
price2num($this->multicurrency_total_tva,
'CT');
3363 $sql .=
", ".(float)
price2num($this->multicurrency_total_ttc,
'CT');
3364 $sql .=
", ".($this->fk_unit ? ((int) $this->fk_unit) :
'null');
3367 dol_syslog(get_class($this).
'::insert', LOG_DEBUG);
3368 $resql = $this->db->query($sql);
3370 $this->
id = $this->db->last_insert_id(MAIN_DB_PREFIX.
'supplier_proposaldet');
3379 if (!$error && !$notrigger) {
3381 $result = $this->call_trigger(
'LINESUPPLIER_PROPOSAL_INSERT', $user);
3383 $this->db->rollback();
3389 $this->db->commit();
3392 $this->error = $this->db->error().
" sql=".$sql;
3393 $this->db->rollback();
3404 public function delete($user)
3410 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"supplier_proposaldet";
3411 $sql .=
" WHERE rowid = ".((int) $this->
id);
3413 if ($this->db->query($sql)) {
3419 dol_syslog(get_class($this).
"::delete error -4 ".$this->error, LOG_ERR);
3424 $result = $this->call_trigger(
'LINESUPPLIER_PROPOSAL_DELETE', $user);
3426 $this->db->rollback();
3431 $this->db->commit();
3435 $this->error = $this->db->error().
" sql=".$sql;
3436 $this->db->rollback();
3454 if (empty($this->tva_tx)) {
3457 if (empty($this->localtax1_tx)) {
3458 $this->localtax1_tx = 0;
3460 if (empty($this->localtax2_tx)) {
3461 $this->localtax2_tx = 0;
3463 if (empty($this->total_localtax1)) {
3464 $this->total_localtax1 = 0;
3466 if (empty($this->total_localtax2)) {
3467 $this->total_localtax2 = 0;
3469 if (empty($this->localtax1_type)) {
3470 $this->localtax1_type =
'';
3472 if (empty($this->localtax2_type)) {
3473 $this->localtax2_type =
'';
3475 if (empty($this->marque_tx)) {
3476 $this->marque_tx = 0;
3478 if (empty($this->marge_tx)) {
3479 $this->marge_tx = 0;
3481 if (empty($this->remise_percent)) {
3482 $this->remise_percent = 0;
3484 if (empty($this->info_bits)) {
3485 $this->info_bits = 0;
3487 if (empty($this->special_code)) {
3488 $this->special_code = 0;
3490 if (empty($this->fk_parent_line)) {
3491 $this->fk_parent_line = 0;
3493 if (empty($this->fk_fournprice)) {
3494 $this->fk_fournprice = 0;
3496 if (empty($this->fk_unit)) {
3499 if (empty($this->subprice)) {
3500 $this->subprice = 0;
3503 if (empty($this->pa_ht)) {
3508 if ($this->pa_ht == 0) {
3509 $result = $this->
defineBuyPrice($this->subprice, $this->remise_percent, $this->fk_product);
3513 $this->pa_ht = $result;
3520 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"supplier_proposaldet SET";
3521 $sql .=
" description = '".$this->db->escape($this->desc).
"'";
3522 $sql .=
" , label = ".(!empty($this->label) ?
"'".$this->db->escape($this->label).
"'" :
"null");
3523 $sql .=
" , product_type = ".((int) $this->product_type);
3524 $sql .=
" , date_start = ".($this->date_start ?
"'".$this->db->idate($this->date_start).
"'" :
"null");
3525 $sql .=
" , date_end = ".($this->date_end ?
"'".$this->db->idate($this->date_end).
"'" :
"null");
3526 $sql .=
" , tva_tx = '".price2num($this->tva_tx).
"'";
3527 $sql .=
" , localtax1_tx = ".(float)
price2num($this->localtax1_tx);
3528 $sql .=
" , localtax2_tx = ".(float)
price2num($this->localtax2_tx);
3529 $sql .=
" , localtax1_type = '".$this->db->escape($this->localtax1_type).
"'";
3530 $sql .=
" , localtax2_type = '".$this->db->escape($this->localtax2_type).
"'";
3531 $sql .=
" , qty = ".(float)
price2num($this->qty);
3532 $sql .=
" , subprice = ".(float)
price2num($this->subprice);
3533 $sql .=
" , subprice_ttc = ".(float)
price2num($this->subprice_ttc);
3534 $sql .=
" , remise_percent = ".(float)
price2num($this->remise_percent);
3535 $sql .=
" , info_bits = ".((int) $this->info_bits);
3536 if (empty($this->skip_update_total)) {
3537 $sql .=
" , total_ht = ".(float)
price2num($this->total_ht);
3538 $sql .=
" , total_tva = ".(float)
price2num($this->total_tva);
3539 $sql .=
" , total_ttc = ".(float)
price2num($this->total_ttc);
3540 $sql .=
" , total_localtax1 = ".(float)
price2num($this->total_localtax1);
3541 $sql .=
" , total_localtax2 = ".(float)
price2num($this->total_localtax2);
3543 $sql .=
" , fk_product_fournisseur_price = ".(!empty($this->fk_fournprice) ?
"'".$this->db->escape((
string) $this->fk_fournprice).
"'" :
"null");
3544 $sql .=
" , buy_price_ht = ".(float)
price2num($this->pa_ht);
3545 $sql .=
" , special_code = ".((int) $this->special_code);
3546 $sql .=
" , fk_parent_line = ".($this->fk_parent_line > 0 ? $this->fk_parent_line :
"null");
3547 if (!empty($this->rang)) {
3548 $sql .=
", rang = ".((int) $this->rang);
3550 $sql .=
" , ref_fourn = ".(!empty($this->ref_fourn) ?
"'".$this->db->escape($this->ref_fourn).
"'" :
"null");
3551 $sql .=
" , fk_unit = ".($this->fk_unit ? (int) $this->fk_unit :
'null');
3554 $sql .=
" , multicurrency_subprice = ".(float)
price2num($this->multicurrency_subprice);
3555 $sql .=
" , multicurrency_subprice_ttc = ".(float)
price2num($this->multicurrency_subprice_ttc);
3556 $sql .=
" , multicurrency_total_ht = ".(float)
price2num($this->multicurrency_total_ht);
3557 $sql .=
" , multicurrency_total_tva = ".(float)
price2num($this->multicurrency_total_tva);
3558 $sql .=
" , multicurrency_total_ttc = ".(float)
price2num($this->multicurrency_total_ttc);
3560 $sql .=
" WHERE rowid = ".((int) $this->
id);
3562 dol_syslog(get_class($this).
"::update", LOG_DEBUG);
3563 $resql = $this->db->query($sql);
3572 if (!$error && !$notrigger) {
3574 $result = $this->call_trigger(
'LINESUPPLIER_PROPOSAL_MODIFY', $user);
3576 $this->db->rollback();
3582 $this->db->commit();
3585 $this->error = $this->db->error();
3586 $this->db->rollback();
3604 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"supplier_proposaldet SET";
3605 $sql .=
" total_ht = ".(float)
price2num($this->total_ht,
'MT');
3606 $sql .=
",total_tva = ".(float)
price2num($this->total_tva,
'MT');
3607 $sql .=
",total_ttc = ".(float)
price2num($this->total_ttc,
'MT');
3608 $sql .=
" WHERE rowid = ".((int) $this->
id);
3610 dol_syslog(
"SupplierProposalLine::update_total", LOG_DEBUG);
3612 $resql = $this->db->query($sql);
3614 $this->db->commit();
3617 $this->error = $this->db->error();
3618 $this->db->rollback();
Parent class of all other business classes (invoices, contracts, proposals, orders,...
fetch_optionals($rowid=null, $optionsArray=null)
Function to get extra fields of an object into $this->array_options This method is in most cases call...
line_order($renum=false, $rowidorder='ASC', $fk_parent_line=true)
Save a new position (field rang) for details lines.
deleteEcmFiles($mode=0)
Delete related files of object in database.
update_price($exclspec=0, $roundingadjust='auto', $nodatabaseupdate=0, $seller=null)
Update total_ht, total_ttc, total_vat, total_localtax1, total_localtax2 for an object (sum of lines).
add_object_linked($origin=null, $origin_id=null, $f_user=null, $notrigger=0)
Add an object link into llx_element_element.
defineBuyPrice($unitPrice=0.0, $discountPercent=0.0, $fk_product=0)
Get buy price to use for margin calculation.
commonGenerateDocument($modelspath, $modele, $outputlangs, $hidedetails, $hidedesc, $hideref, $moreparams=null)
Common function for all objects extending CommonObject for generating documents.
fetch_thirdparty($force_thirdparty_id=0)
Load the third party of object, from id $this->socid or $this->fk_soc, into this->thirdparty.
deleteObjectLinked($sourceid=null, $sourcetype='', $targetid=null, $targettype='', $rowid=0, $f_user=null, $notrigger=0)
Delete all links between an object $this.
setErrorsFromObject($object)
setErrorsFromObject
static isExistingObject($element, $id, $ref='', $ref_ext='')
Check if an object id or ref exists If you don't need or want to instantiate the object and just need...
updateRangOfLine($rowid, $rang)
Update position of line (rang)
checkActiveProductInLines($status='onsale')
Check if all products have the right status (on sale, on buy) called during validation of propal,...
deleteExtraFields()
Delete all extra fields values for the current object.
static commonReplaceThirdparty(DoliDB $dbs, $origin_id, $dest_id, array $tables, $ignoreerrors=0)
Function used to replace a thirdparty id with another one.
static commonReplaceProduct(DoliDB $dbs, $origin_id, $dest_id, array $tables, $ignoreerrors=0)
Function used to replace a product id with another one.
line_max($fk_parent_line=0)
Get max value used for position of line (rang)
insertExtraFields($trigger='', $userused=null)
Add/Update all extra fields values for the current object.
add_contact($fk_socpeople, $type_contact, $source='external', $notrigger=0)
Add a link between element $this->element and a contact.
Parent class for class inheritance lines of business objects This class is useless for the moment so ...
Class to manage absolute discounts.
Class to manage Dolibarr database access.
static getIdAndTxFromCode($dbs, $code, $date_document=0)
Get id and rate of currency from code.
Class to manage predefined suppliers products.
Class to manage products or services.
const TYPE_PRODUCT
Regular product.
Class to manage third parties objects (customers, suppliers, prospects...)
Class to manage price ask supplier.
updatePriceFournisseur($idProductFournPrice, $product, $user)
Update ProductFournisseur.
updateline($rowid, $pu, $qty, $remise_percent, $txtva, $txlocaltax1=0, $txlocaltax2=0, $desc='', $price_base_type='HT', $info_bits=0, $special_code=0, $fk_parent_line=0, $skip_update_total=0, $fk_fournprice=0, $pa_ht=0, $label='', $type=0, $array_options=[], $ref_supplier='', $fk_unit=0, $pu_ht_devise=0)
Update a proposal line.
cloture($user, $status, $note)
Close the askprice.
initAsSpecimen($param=array())
Initialise an instance with random values.
generateDocument($modele, $outputlangs, $hidedetails=0, $hidedesc=0, $hideref=0, $moreparams=null)
Create a document onto disk according to template module.
addline($desc, $pu_ht, $qty, $txtva, $txlocaltax1=0, $txlocaltax2=0, $fk_product=0, $remise_percent=0, $price_base_type='HT', $pu_ttc=0, $info_bits=0, $type=0, $rang=-1, $special_code=0, $fk_parent_line=0, $fk_fournprice=0, $pa_ht=0, $label='', $array_options=[], $ref_supplier='', $fk_unit=0, $origin='', $origin_id=0, $pu_ht_devise=0, $date_start=0, $date_end=0)
Add a proposal line into database (linked to product/service or not) The parameters are already suppo...
info($id)
Object SupplierProposal Information.
create($user, $notrigger=0)
Create commercial proposal into database this->ref can be set or empty.
insert_discount($idremise)
Adding line of fixed discount in the proposal in DB.
reopen($user, $status, $note='', $notrigger=0)
Reopen the commercial proposal.
static replaceProduct(DoliDB $db, $origin_id, $dest_id)
Function used to replace a product id with another one.
fetch($rowid, $ref='')
Load a proposal from database and its lines array.
load_board($user, $mode)
Load indicators for dashboard (this->nbtodo and this->nbtodolate)
createFromClone(User $user, $fromid=0)
Load an object from its id and create a new one in database.
const STATUS_NOTSIGNED
Not signed quote, canceled.
const STATUS_DRAFT
Draft status.
liste_array($shortlist=0, $draft=0, $notcurrentuser=0, $socid=0, $limit=0, $offset=0, $sortfield='p.datec', $sortorder='DESC')
Return list of askprice (eventually filtered on user) into an array.
setDeliveryDate($user, $delivery_date)
Set delivery date.
__construct($db, $socid=0, $supplier_proposalid=0)
Constructor.
LibStatut($status, $mode=1)
Return label of a status (draft, validated, ...)
setCategories($categories)
Sets object to supplied categories.
static replaceThirdparty(DoliDB $dbs, $origin_id, $dest_id)
Function used to replace a thirdparty id with another one.
updateOrCreatePriceFournisseur($user)
Add or update supplier price according to result of proposal.
loadStateBoard()
Load indicator this->nb of global stats widget.
deleteLine($lineid)
Delete detail line.
const STATUS_VALIDATED
Validated status.
createPriceFournisseur($product, $user)
Create Price Fournisseur.
getLibStatut($mode=0)
Return label of status of proposal (draft, validated, ...)
add_product($idproduct, $qty, $remise_percent=0)
Add line into array ->lines.
set_date_livraison($user, $delivery_date)
Set delivery date.
const STATUS_SIGNED
Signed quote.
getNomUrl($withpicto=0, $option='', $get_params='', $notooltip=0, $save_lastsearch_value=-1, $addlinktonotes=0)
Return clickable link of object (with eventually picto)
getKanbanView($option='', $arraydata=null)
Return clickable link of object (with eventually picto)
getTooltipContentArray($params)
getTooltipContentArray
valid($user, $notrigger=0)
Set status to validated.
const STATUS_CLOSE
Billed or closed/processed quote.
getLinesArray()
Retrieve an array of supplier proposal lines.
setDraft($user)
Set draft status.
Class to manage supplier_proposal lines.
fetch($rowid)
Retrieve the propal line object.
insert($notrigger=0)
Insert object line propal in database.
update_total()
Update DB line fields total_xxx Used by migration.
update($notrigger=0)
Update propal line object into DB.
__construct($db)
Class line Constructor.
Class to manage translations.
Class to manage Dolibarr users.
print $langs trans("Ref").' m titre as m m statut as status
Or an array listing all the potential status of the object: array: int of the status => translated la...
dol_delete_file($file, $disableglob=0, $nophperrors=0, $nohook=0, $object=null, $allowdotdot=false, $indexdatabase=1, $nolog=0)
Remove a file or several files with a mask.
dol_delete_dir_recursive($dir, $count=0, $nophperrors=0, $onlysub=0, &$countdeleted=0, $indexdatabase=1, $nolog=0, $level=0)
Remove a directory $dir and its subdirectories (or only files and subdirectories)
dol_dir_list($utf8_path, $types="all", $recursive=0, $filter="", $excludefilter=null, $sortcriteria="name", $sortorder=SORT_ASC, $mode=0, $nohook=0, $relativename="", $donotfollowsymlinks=0, $nbsecondsold=0)
Scan a directory and return a list of files/directories.
dol_delete_preview($object)
Delete all preview files linked to object instance.
$date_start
Variables from include:
dol_now($mode='gmt')
Return date for now.
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)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_string_nohtmltag($stringtoclean, $removelinefeed=1, $pagecodeto='UTF-8', $strip_tags=0, $removedoublespaces=1)
Clean a string from all HTML tags and entities.
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $allowothertags=array())
Show a picto called object_picto (generic function)
dol_sanitizeFileName($str, $newstr='_', $unaccent=1, $includequotes=0, $allowdash=0)
Clean a string to use it as a file name.
dol_strlen($string, $stringencoding='UTF-8')
Make a strlen call.
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.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
getLocalTaxesFromRate($vatrate, $local, $buyer, $seller, $firstparamisid=0)
Get type and rate of localtaxes for a particular vat rate/country of a thirdparty.
get_default_npr(Societe $thirdparty_seller, Societe $thirdparty_buyer, $idprod=0, $idprodfournprice=0)
Function that returns whether VAT must be recoverable collected VAT (e.g.: VAT NPR in France)
getDolCurrency()
Return the main currency ('EUR', 'USD', ...)
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_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).
getDolGlobalBool($key, $default=false)
Return a Dolibarr global constant boolean value.
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
isModEnabled($module)
Is Dolibarr module enabled.
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.
getEntity($element, $shared=1, $currentobject=null)
Get list of entity id to use.
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...
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
getMarginInfos($pv_ht, $remise_percent, $tva_tx, $localtax1_tx, $localtax2_tx, $fk_pa, $pa_ht)
Return an array with margins information of a line.
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.
print $langs trans('Date')." left Ref Label right Qty right Price right TotalHT right TotalTTC right right right right right right right right right centpercent right TotalHT right n right VAT right n right TotalVAT right n No sujeto a RE IRPF right TotalLT1 right n right TotalLT2 right n right TotalTTC right n takeposcustomercurrency takeposcustomercurrency takeposcustomercurrency takeposcustomercurrency right TotalTTC takeposcustomercurrency right takeposcustomercurrency n right Paid right PaymentTypeShortLIQ right SELECT p pos_change as p datep as date