33require_once DOL_DOCUMENT_ROOT.
'/core/class/notify.class.php';
34require_once DOL_DOCUMENT_ROOT.
'/product/class/product.class.php';
35require_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.facture.class.php';
36require_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.facture-rec.ligne.class.php';
37require_once DOL_DOCUMENT_ROOT.
'/core/lib/date.lib.php';
45 const TRIGGER_PREFIX =
'SUPPLIERBILLREC';
49 public $element =
'invoice_supplier_rec';
54 public $table_element =
'facture_fourn_rec';
59 public $table_element_line =
'facture_fourn_det_rec';
64 public $fk_element =
'fk_facture_fourn';
69 public $picto =
'bill';
131 public $vat_src_code;
157 public $mode_reglement_id;
161 public $mode_reglement_code;
165 public $cond_reglement_code;
169 public $cond_reglement_doc;
173 public $cond_reglement_id;
178 public $date_lim_reglement;
183 public $usenewprice = 0;
191 public $unit_frequency;
199 public $date_last_gen;
214 public $auto_validate;
218 public $generate_pdf;
224 public $lines = array();
267 public $fields = array(
268 'rowid' => array(
'type' =>
'integer',
'label' =>
'TechnicalID',
'enabled' => 1,
'visible' => -1,
'notnull' => 1,
'position' => 10),
269 'titre' => array(
'type' =>
'varchar(100)',
'label' =>
'Titre',
'enabled' => 1,
'showoncombobox' => 1,
'visible' => -1,
'position' => 15),
270 'ref_supplier' => array(
'type' =>
'varchar(180)',
'label' =>
'RefSupplier',
'enabled' => 1,
'showoncombobox' => 1,
'visible' => -1,
'position' => 20),
271 'entity' => array(
'type' =>
'integer',
'label' =>
'Entity',
'default' =>
'1',
'enabled' => 1,
'visible' => -2,
'notnull' => 1,
'position' => 25,
'index' => 1),
272 'fk_soc' => array(
'type' =>
'integer:Societe:societe/class/societe.class.php',
'label' =>
'ThirdParty',
'enabled' =>
'isModEnabled("societe")',
'visible' => -1,
'notnull' => 1,
'position' => 30),
273 'datec' => array(
'type' =>
'datetime',
'label' =>
'DateCreation',
'enabled' => 1,
'visible' => -1,
'position' => 35),
274 'tms' => array(
'type' =>
'timestamp',
'label' =>
'DateModification',
'enabled' => 1,
'visible' => -1,
'notnull' => 1,
'position' => 40),
275 'suspended' => array(
'type' =>
'integer',
'label' =>
'Suspended',
'enabled' => 1,
'visible' => -1,
'position' => 225),
276 'libelle' => array(
'type' =>
'varchar(100)',
'label' =>
'Libelle',
'enabled' => 1,
'showoncombobox' => 0,
'visible' => -1,
'position' => 15),
278 'localtax1' => array(
'type' =>
'double(24,8)',
'label' =>
'Localtax1',
'enabled' => 1,
'visible' => -1,
'position' => 60,
'isameasure' => 1),
279 'localtax2' => array(
'type' =>
'double(24,8)',
'label' =>
'Localtax2',
'enabled' => 1,
'visible' => -1,
'position' => 65,
'isameasure' => 1),
280 'total_ht' => array(
'type' =>
'double(24,8)',
'label' =>
'Total',
'enabled' => 1,
'visible' => -1,
'position' => 70,
'isameasure' => 1),
281 'total_tva' => array(
'type' =>
'double(24,8)',
'label' =>
'Tva',
'enabled' => 1,
'visible' => -1,
'position' => 55,
'isameasure' => 1),
282 'total_ttc' => array(
'type' =>
'double(24,8)',
'label' =>
'Total ttc',
'enabled' => 1,
'visible' => -1,
'position' => 75,
'isameasure' => 1),
284 'fk_user_author' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'Fk user author',
'enabled' => 1,
'visible' => -1,
'position' => 80),
285 'fk_user_modif' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserModif',
'enabled' => 1,
'visible' => -2,
'notnull' => -1,
'position' => 210),
286 'fk_projet' => array(
'type' =>
'integer:Project:projet/class/project.class.php:1:fk_statut=1',
'label' =>
'Fk projet',
'enabled' =>
"isModEnabled('project')",
'visible' => -1,
'position' => 85),
287 'fk_account' => array(
'type' =>
'integer',
'label' =>
'Fk account',
'enabled' =>
'isModEnabled("bank")',
'visible' => -1,
'position' => 175),
288 'fk_cond_reglement' => array(
'type' =>
'integer',
'label' =>
'Fk cond reglement',
'enabled' => 1,
'visible' => -1,
'position' => 90),
289 'fk_mode_reglement' => array(
'type' =>
'integer',
'label' =>
'Fk mode reglement',
'enabled' => 1,
'visible' => -1,
'position' => 95),
290 'date_lim_reglement' => array(
'type' =>
'date',
'label' =>
'Date lim reglement',
'enabled' => 1,
'visible' => -1,
'position' => 100),
292 'note_private' => array(
'type' =>
'html',
'label' =>
'NotePublic',
'enabled' => 1,
'visible' => 0,
'position' => 105),
293 'note_public' => array(
'type' =>
'html',
'label' =>
'NotePrivate',
'enabled' => 1,
'visible' => 0,
'position' => 110),
294 'modelpdf' => array(
'type' =>
'varchar(255)',
'label' =>
'Modelpdf',
'enabled' => 1,
'visible' => -1,
'position' => 115),
296 'fk_multicurrency' => array(
'type' =>
'integer',
'label' =>
'Fk multicurrency',
'enabled' => 1,
'visible' => -1,
'position' => 180),
297 'multicurrency_code' => array(
'type' =>
'varchar(255)',
'label' =>
'Multicurrency code',
'enabled' => 1,
'visible' => -1,
'position' => 185),
298 'multicurrency_tx' => array(
'type' =>
'double(24,8)',
'label' =>
'Multicurrency tx',
'enabled' => 1,
'visible' => -1,
'position' => 190,
'isameasure' => 1),
299 'multicurrency_total_ht' => array(
'type' =>
'double(24,8)',
'label' =>
'Multicurrency total ht',
'enabled' => 1,
'visible' => -1,
'position' => 195,
'isameasure' => 1),
300 'multicurrency_total_tva' => array(
'type' =>
'double(24,8)',
'label' =>
'Multicurrency total tva',
'enabled' => 1,
'visible' => -1,
'position' => 200,
'isameasure' => 1),
301 'multicurrency_total_ttc' => array(
'type' =>
'double(24,8)',
'label' =>
'Multicurrency total ttc',
'enabled' => 1,
'visible' => -1,
'position' => 205,
'isameasure' => 1),
303 'usenewprice' => array(
'type' =>
'integer',
'label' =>
'UseNewPrice',
'enabled' => 1,
'visible' => 0,
'position' => 155),
304 'frequency' => array(
'type' =>
'integer',
'label' =>
'Frequency',
'enabled' => 1,
'visible' => -1,
'position' => 150),
305 'unit_frequency' => array(
'type' =>
'varchar(2)',
'label' =>
'Unit frequency',
'enabled' => 1,
'visible' => -1,
'position' => 125),
307 'date_when' => array(
'type' =>
'datetime',
'label' =>
'Date when',
'enabled' => 1,
'visible' => -1,
'position' => 130),
308 'date_last_gen' => array(
'type' =>
'datetime',
'label' =>
'Date last gen',
'enabled' => 1,
'visible' => -1,
'position' => 135),
309 'nb_gen_done' => array(
'type' =>
'integer',
'label' =>
'Nb gen done',
'enabled' => 1,
'visible' => -1,
'position' => 140),
310 'nb_gen_max' => array(
'type' =>
'integer',
'label' =>
'Nb gen max',
'enabled' => 1,
'visible' => -1,
'position' => 145),
311 'revenuestamp' => array(
'type' =>
'double(24,8)',
'label' =>
'RevenueStamp',
'enabled' => 1,
'visible' => -1,
'position' => 160,
'isameasure' => 1),
312 'auto_validate' => array(
'type' =>
'integer',
'label' =>
'Auto validate',
'enabled' => 1,
'visible' => -1,
'position' => 165),
313 'generate_pdf' => array(
'type' =>
'integer',
'label' =>
'Generate pdf',
'enabled' => 1,
'visible' => -1,
'position' => 170),
317 const STATUS_NOTSUSPENDED = 0;
318 const STATUS_SUSPENDED = 1;
340 public function create($user, $facFournId, $notrigger = 0)
348 $this->titre = empty($this->titre) ?
'' : $this->titre;
349 $this->title = empty($this->title) ?
'' : $this->title;
351 $this->
ref = $this->$keyforref;
352 $this->ref_supplier = empty($this->ref_supplier) ?
'' : $this->ref_supplier;
353 $this->usenewprice = empty($this->usenewprice) ? 0 : $this->usenewprice;
354 $this->suspended = empty($this->suspended) ? 0 : $this->suspended;
356 if (empty($this->frequency)) {
357 $this->frequency = 0;
358 $this->date_when =
null;
360 $this->frequency = abs($this->frequency);
361 $this->nb_gen_done = 0;
362 $this->nb_gen_max = empty($this->nb_gen_max) ? 0 : $this->nb_gen_max;
363 $this->auto_validate = empty($this->auto_validate) ? 0 : $this->auto_validate;
364 $this->generate_pdf = empty($this->generate_pdf) ? 0 : $this->generate_pdf;
370 $result = $facfourn_src->fetch($facFournId);
372 $sql =
'INSERT INTO '.MAIN_DB_PREFIX.
'facture_fourn_rec (';
375 $sql .=
', ref_supplier';
379 $sql .=
', suspended';
381 $sql .=
', total_ttc';
382 $sql .=
', fk_user_author';
383 $sql .=
', fk_projet';
384 $sql .=
', fk_account';
385 $sql .=
', fk_cond_reglement';
386 $sql .=
', fk_mode_reglement';
387 $sql .=
', date_lim_reglement';
388 $sql .=
', note_private';
389 $sql .=
', note_public';
390 $sql .=
', modelpdf';
391 $sql .=
', fk_multicurrency';
392 $sql .=
', multicurrency_code';
393 $sql .=
', multicurrency_tx';
394 $sql .=
', usenewprice';
395 $sql .=
', frequency';
396 $sql .=
', unit_frequency';
397 $sql .=
', date_when';
398 $sql .=
', date_last_gen';
399 $sql .=
', nb_gen_done';
400 $sql .=
', nb_gen_max';
401 $sql .=
', auto_validate';
402 $sql .=
', generate_pdf';
403 $sql .=
') VALUES (';
404 $sql .=
"'".$this->db->escape($this->title).
"'";
405 $sql .=
", ".($this->subtype ?
"'".$this->db->escape($this->subtype).
"'" :
"null");
406 $sql .=
", '".$this->db->escape($this->ref_supplier).
"'";
407 $sql .=
", ".((int) $conf->entity);
408 $sql .=
", ".((int) $facfourn_src->socid);
409 $sql .=
", '".$this->db->idate($now).
"'";
410 $sql .=
", ".((int) $this->suspended);
411 $sql .=
", '".$this->db->escape($this->libelle).
"'";
412 $sql .=
", " .(!empty($facfourn_src->total_ttc) ? (float) $facfourn_src->total_ttc :
'0');
413 $sql .=
", " .((int) $user->id);
414 $sql .=
", " .(!empty($this->fk_project) ? ((int) $this->fk_project) :
'NULL');
415 $sql .=
", " .(!empty($facfourn_src->fk_account) ? ((int) $facfourn_src->fk_account) :
'NULL');
416 $sql .=
", " .($this->cond_reglement_id > 0 ? (int) $this->cond_reglement_id :
'NULL');
417 $sql .=
", " .($this->mode_reglement_id > 0 ? (int) $this->mode_reglement_id :
'NULL');
418 $sql .=
", ".($facfourn_src->date_echeance > 0 ?
"'".$this->db->idate($facfourn_src->date_echeance).
"'" :
'NULL');
419 $sql .=
", " .(!empty($this->note_private) ?
"'".$this->db->escape($this->note_private).
"'" :
'NULL');
420 $sql .=
", " .(!empty($this->note_public) ?
"'".$this->db->escape($this->note_public).
"'" :
'NULL');
421 $sql .=
", " .(!empty($this->model_pdf) ?
"'".$this->db->escape($this->model_pdf).
"'" :
'NULL');
422 $sql .=
", " . (int) $facfourn_src->fk_multicurrency;
423 $sql .=
", '".$this->db->escape($facfourn_src->multicurrency_code).
"'";
424 $sql .=
", " . (float) $facfourn_src->multicurrency_tx;
425 $sql .=
", " . (int) $this->usenewprice;
426 $sql .=
", " . (int) $this->frequency;
427 $sql .=
", '".$this->db->escape($this->unit_frequency).
"'";
428 $sql .=
", " .(!empty($this->date_when) ?
"'".$this->db->idate($this->date_when).
"'" :
'NULL');
429 $sql .=
", " .(!empty($this->date_last_gen) ?
"'".$this->db->idate($this->date_last_gen).
"'" :
'NULL');
430 $sql .=
", " . (int) $this->nb_gen_done;
431 $sql .=
", " . (int) $this->nb_gen_max;
432 $sql .=
", " . (int) $this->auto_validate;
433 $sql .=
", " . (int) $this->generate_pdf;
436 if ($this->db->query($sql)) {
437 $this->
id = $this->db->last_insert_id(MAIN_DB_PREFIX.
'facture_fourn_rec');
440 $this->fk_multicurrency = $facfourn_src->fk_multicurrency;
442 $this->multicurrency_code = $facfourn_src->multicurrency_code;
443 $this->multicurrency_tx = $facfourn_src->multicurrency_tx;
446 $num = count($facfourn_src->lines);
447 for ($i = 0; $i < $num; $i++) {
448 $facfourn_line = $facfourn_src->lines[$i];
449 '@phan-var-force SupplierInvoiceLine $facfourn_line';
451 $tva_tx = $facfourn_line->tva_tx;
452 if (!empty($facfourn_line->vat_src_code) && !preg_match(
'/\(/', (
string) $tva_tx)) {
453 $tva_tx .=
' ('.$facfourn_line->vat_src_code.
')';
456 $result_insert = $this->
addline(
457 $facfourn_line->fk_product,
458 $facfourn_line->ref_supplier,
459 $facfourn_line->product_label,
460 $facfourn_line->desc ? $facfourn_line->desc : $facfourn_line->description,
461 $facfourn_line->pu_ht,
462 $facfourn_line->pu_ttc,
464 $facfourn_line->remise_percent,
466 $facfourn_line->localtax1_tx,
467 $facfourn_line->localtax2_tx,
469 $facfourn_line->product_type,
470 $facfourn_line->date_start,
471 $facfourn_line->date_end,
472 $facfourn_line->info_bits,
473 $facfourn_line->special_code,
474 $facfourn_line->rang,
475 $facfourn_line->fk_unit
478 if ($result_insert < 0) {
483 $result2 = $objectline->fetch($result_insert);
486 if (method_exists($facfourn_line,
'fetch_optionals')) {
487 $facfourn_line->fetch_optionals($facfourn_line->id);
488 $objectline->array_options = $facfourn_line->array_options;
491 $result = $objectline->insertExtraFields();
495 } elseif ($result2 < 0) {
496 $this->errors[] = $objectline->error;
502 if (!empty($this->linkedObjectsIds) && empty($this->linked_objects)) {
503 $this->linked_objects = $this->linkedObjectsIds;
507 if (!$error && $this->
id && !empty($this->linked_objects) && is_array($this->linked_objects)) {
508 foreach ($this->linked_objects as $origin => $tmp_origin_id) {
509 if (is_array($tmp_origin_id)) {
510 foreach ($tmp_origin_id as $origin_id) {
513 $this->error = $this->db->lasterror();
518 $origin_id = $tmp_origin_id;
521 $this->error = $this->db->lasterror();
535 if (!$error && !$notrigger) {
537 $result = $this->
call_trigger(
'SUPPLIERBILLREC_CREATE', $user);
539 $this->db->rollback();
546 $this->db->rollback();
553 $this->error = $this->db->lasterror();
554 $this->db->rollback();
558 $this->db->rollback();
575 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"facture_fourn_rec SET";
576 $sql .=
" titre = '" . (!empty($this->title) ? $this->db->escape($this->title) :
"").
"'," ;
577 $sql .=
" subtype=".(isset($this->subtype) ? $this->db->escape($this->subtype) :
"null").
",";
578 $sql .=
" ref_supplier = '". (!empty($this->ref_supplier) ? $this->db->escape($this->ref_supplier) :
"").
"',";
579 $sql .=
" entity = ". (!empty($this->entity) ? ((int) $this->entity) : 1) .
',';
580 if (!empty($this->socid) && $this->socid > 0) {
581 $sql .=
" fk_soc = ". ((int) $this->socid).
',';
582 } elseif (!empty($this->fk_soc) && $this->fk_soc > 0) {
583 $sql .=
" fk_soc = ". ((int) $this->fk_soc).
',';
585 $sql .=
" suspended = ". (!empty($this->suspended) ? ((int) $this->suspended) : 0) .
',';
586 $sql .=
" libelle = ". (!empty($this->libelle) ?
"'".$this->db->escape($this->libelle).
"'" :
'NULL') .
",";
587 $sql .=
" vat_src_code = ". (!empty($this->vat_src_code) ?
"'".$this->db->escape($this->vat_src_code).
"'" :
'NULL') .
',';
588 $sql .=
" localtax1 = ". (!empty($this->localtax1) ? ((float) $this->localtax1) : 0.00) .
',';
589 $sql .=
" localtax2 = ". (!empty($this->localtax2) ? ((float) $this->localtax2) : 0.00) .
',';
590 $sql .=
" total_ht = ". (!empty($this->total_ht) ? ((float) $this->total_ht) : 0.00) .
',';
591 $sql .=
" total_tva = ". (!empty($this->total_tva) ? ((float) $this->total_tva) : 0.00) .
',';
592 $sql .=
" total_ttc = ". (!empty($this->total_ttc) ? ((float) $this->total_ttc) : 0.00) .
',';
593 $sql .=
" fk_user_modif = ". ((int) $user->id) .
',';
594 $sql .=
" fk_projet = ". (!empty($this->fk_project) ? ((int) $this->fk_project) :
'NULL') .
',';
595 $sql .=
" fk_account = ". (!empty($this->fk_account) ? ((int) $this->fk_account) :
'NULL') .
',';
596 $sql .=
" fk_mode_reglement = ". (!empty($this->mode_reglement_id) ? ((int) $this->mode_reglement_id) :
'NULL') .
',';
597 $sql .=
" fk_cond_reglement = ". (!empty($this->cond_reglement_id) ? ((int) $this->cond_reglement_id) :
'NULL') .
',';
598 $sql .=
" date_lim_reglement = ". (!empty($this->date_lim_reglement) ?
"'".$this->db->idate($this->date_lim_reglement).
"'" :
'NULL') .
',';
599 $sql .=
" note_private = '". (!empty($this->note_private) ? $this->db->escape($this->note_private) :
'') .
"',";
600 $sql .=
" note_public = '". (!empty($this->note_public) ? $this->db->escape($this->note_public) :
'') .
"',";
601 $sql .=
" modelpdf = ". (!empty($this->model_pdf) ?
"'".$this->db->escape($this->model_pdf).
"'" :
'NULL') .
",";
602 $sql .=
" fk_multicurrency = ". (!empty($this->fk_multicurrency) ? ((int) $this->fk_multicurrency) :
'NULL') .
',';
603 $sql .=
" multicurrency_code = ". (!empty($this->multicurrency_code) ?
"'".$this->db->escape($this->multicurrency_code).
"'" :
'NULL') .
",";
604 $sql .=
" multicurrency_tx = ". (!empty($this->multicurrency_tx) ? ((float) $this->multicurrency_tx) : 1) .
',';
605 $sql .=
" multicurrency_total_ht = ". (!empty($this->multicurrency_total_ht) ? ((float) $this->multicurrency_total_ht) : 0.00) .
',';
606 $sql .=
" multicurrency_total_tva = ". (!empty($this->multicurrency_total_tva) ? ((float) $this->multicurrency_total_tva) : 0.00) .
',';
607 $sql .=
" multicurrency_total_ttc = ". (!empty($this->multicurrency_total_ttc) ? ((float) $this->multicurrency_total_ttc) : 0.00) .
',';
608 $sql .=
" usenewprice = ". (!empty($this->usenewprice) ? ((int) $this->usenewprice) : 0) .
',';
609 $sql .=
" frequency = ". (!empty($this->frequency) ? ((int) $this->frequency) : 0).
',';
610 $sql .=
" unit_frequency = '". (!empty($this->unit_frequency) ? $this->db->escape($this->unit_frequency) :
'').
"',";
611 $sql .=
" date_when = ". (!empty($this->date_when) ?
"'".$this->db->idate($this->date_when).
"'" :
'NULL') .
',';
612 $sql .=
" date_last_gen = ". (!empty($this->date_last_gen) ?
"'".$this->db->idate($this->date_last_gen).
"'" :
'NULL') .
',';
613 $sql .=
" nb_gen_done = ". (!empty($this->nb_gen_done) ? ((int) $this->nb_gen_done) : 0) .
',';
614 $sql .=
" nb_gen_max = ". (!empty($this->nb_gen_max) ? ((int) $this->nb_gen_max) : 0) .
',';
615 $sql .=
" auto_validate = ". (!empty($this->auto_validate) ? ((int) $this->auto_validate) : 0);
616 $sql .=
" WHERE rowid = ". (int) $this->
id;
620 dol_syslog(get_class($this).
"::update", LOG_DEBUG);
621 $resql = $this->db->query($sql);
630 if (!$error && !$notrigger) {
632 $result = $this->
call_trigger(
'SUPPLIERBILLREC_MODIFY', $user);
634 $this->db->rollback();
642 $this->error = $this->db->lasterror();
643 $this->db->rollback();
656 public function fetch($rowid, $ref =
'', $ref_ext =
'')
658 $sql =
'SELECT f.rowid, f.titre as title, f.subtype, f.ref_supplier, f.entity, f.fk_soc';
659 $sql .=
', f.datec, f.tms, f.suspended';
660 $sql .=
', f.libelle as label';
661 $sql .=
', f.vat_src_code, f.localtax1, f.localtax2';
662 $sql .=
', f.total_tva, f.total_ht, f.total_ttc';
663 $sql .=
', f.fk_user_author, f.fk_user_modif';
664 $sql .=
', f.fk_projet as fk_project, f.fk_account';
665 $sql .=
', f.fk_mode_reglement, p.code as mode_reglement_code, p.libelle as mode_reglement_libelle';
666 $sql .=
', f.fk_cond_reglement, c.code as cond_reglement_code, c.libelle as cond_reglement_libelle, c.libelle_facture as cond_reglement_libelle_doc';
667 $sql .=
', f.date_lim_reglement';
668 $sql .=
', f.note_private, f.note_public, f.modelpdf as model_pdf';
669 $sql .=
', f.fk_multicurrency, f.multicurrency_code, f.multicurrency_tx, f.multicurrency_total_ht, f.multicurrency_total_tva, f.multicurrency_total_ttc';
670 $sql .=
', f.usenewprice, f.frequency, f.unit_frequency, f.date_when, f.date_last_gen, f.nb_gen_done, f.nb_gen_max, f.auto_validate';
671 $sql .=
', f.generate_pdf';
672 $sql .=
' FROM '.MAIN_DB_PREFIX.
'facture_fourn_rec as f';
673 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_payment_term as c ON f.fk_cond_reglement = c.rowid';
674 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_paiement as p ON f.fk_mode_reglement = p.id';
675 $sql .=
' WHERE f.entity IN ('.getEntity(
'invoice').
')';
677 $sql .=
' AND f.rowid='. (int) $rowid;
679 $sql .=
" AND f.titre='".$this->db->escape($ref).
"'";
681 $sql .=
' AND f.rowid = 0';
684 $result = $this->db->query($sql);
686 if ($this->db->num_rows($result)) {
687 $obj = $this->db->fetch_object($result);
691 $this->
id = $obj->rowid;
692 $this->titre = $obj->title;
693 $this->title = $obj->title;
694 $this->subtype = $obj->subtype;
695 $this->
ref = $obj->title;
696 $this->ref_supplier = $obj->ref_supplier;
697 $this->entity = $obj->entity;
698 $this->socid = $obj->fk_soc;
699 $this->date_creation = $obj->datec;
700 $this->date_modification = $obj->tms;
701 $this->suspended = $obj->suspended;
702 $this->libelle = $obj->label;
703 $this->label = $obj->label;
704 $this->vat_src_code = $obj->vat_src_code;
705 $this->total_localtax1 = $obj->localtax1;
706 $this->total_localtax2 = $obj->localtax2;
707 $this->total_ht = $obj->total_ht;
708 $this->total_tva = $obj->total_tva;
709 $this->total_ttc = $obj->total_ttc;
710 $this->user_author = $obj->fk_user_author;
711 $this->user_modif = $obj->fk_user_modif;
712 $this->fk_project = $obj->fk_project;
713 $this->fk_account = $obj->fk_account;
714 $this->mode_reglement_id = $obj->fk_mode_reglement;
715 $this->mode_reglement_code = $obj->mode_reglement_code;
716 $this->mode_reglement = $obj->mode_reglement_libelle;
717 $this->cond_reglement_id = $obj->fk_cond_reglement;
718 $this->cond_reglement_code = $obj->cond_reglement_code;
719 $this->cond_reglement = $obj->cond_reglement_libelle;
720 $this->cond_reglement_doc = $obj->cond_reglement_libelle_doc;
721 $this->date_lim_reglement = $this->db->jdate($obj->date_lim_reglement);
722 $this->note_private = $obj->note_private;
723 $this->note_public = $obj->note_public;
724 $this->model_pdf = $obj->model_pdf;
727 $this->fk_multicurrency = $obj->fk_multicurrency;
728 $this->multicurrency_code = $obj->multicurrency_code;
729 $this->multicurrency_tx = $obj->multicurrency_tx;
730 $this->multicurrency_total_ht = $obj->multicurrency_total_ht;
731 $this->multicurrency_total_tva = $obj->multicurrency_total_tva;
732 $this->multicurrency_total_ttc = $obj->multicurrency_total_ttc;
734 $this->usenewprice = $obj->usenewprice;
735 $this->frequency = $obj->frequency;
736 $this->unit_frequency = $obj->unit_frequency;
737 $this->date_when = $this->db->jdate($obj->date_when);
738 $this->date_last_gen = $this->db->jdate($obj->date_last_gen);
739 $this->nb_gen_done = $obj->nb_gen_done;
740 $this->nb_gen_max = $obj->nb_gen_max;
741 $this->auto_validate = $obj->auto_validate;
742 $this->generate_pdf = $obj->generate_pdf;
753 $this->error = $this->db->lasterror();
758 $this->error =
'Bill with id '.$rowid.
' or ref '.$ref.
' not found';
759 dol_syslog(
'Facture::Fetch Error '.$this->error, LOG_ERR);
763 $this->error = $this->db->error();
788 $this->lines = array();
799 $sql =
'SELECT l.rowid,';
800 $sql .=
' l.fk_facture_fourn, l.fk_parent_line, l.fk_product, l.ref, l.label, l.description as line_desc,';
801 $sql .=
' l.pu_ht, l.pu_ttc, l.qty, l.remise_percent, l.fk_remise_except, l.vat_src_code, l.tva_tx,';
802 $sql .=
' l.localtax1_tx, l.localtax2_tx, l.localtax1_type, l.localtax2_type,';
803 $sql .=
' l.total_ht, l.total_tva, l.total_ttc, total_localtax1, total_localtax2,';
804 $sql .=
' l.product_type, l.date_start, l.date_end,';
805 $sql .=
' l.info_bits, l.special_code, l.rang,';
806 $sql .=
' l.fk_unit, l.import_key, l.fk_user_author, l.fk_user_modif,';
807 $sql .=
' l.fk_multicurrency, l.multicurrency_code, l.multicurrency_subprice, l.multicurrency_total_ht, l.multicurrency_total_tva, l.multicurrency_total_ttc,';
808 $sql .=
' p.ref as product_ref, p.fk_product_type as fk_product_type, p.label as product_label, p.description as product_desc';
809 $sql .=
' FROM '.MAIN_DB_PREFIX.
'facture_fourn_det_rec as l';
810 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'product as p ON l.fk_product = p.rowid';
811 $sql .=
' WHERE l.fk_facture_fourn = '. (int) $this->
id;
812 $sql .=
' ORDER BY l.rang';
814 dol_syslog(
'FactureFournisseurRec::fetch_lines', LOG_DEBUG);
816 $result = $this->db->query($sql);
818 $num = $this->db->num_rows($result);
821 $objp = $this->db->fetch_object($result);
825 $line->id = $objp->rowid;
826 $line->fk_facture_fourn = $objp->fk_facture_fourn;
827 $line->fk_parent = $objp->fk_parent_line;
828 $line->fk_product = $objp->fk_product;
829 $line->ref_supplier = $objp->ref;
830 $line->label = $objp->label;
831 $line->description = $objp->line_desc;
832 $line->desc = $objp->line_desc;
833 $line->pu_ht = $objp->pu_ht;
834 $line->pu_ttc = $objp->pu_ttc;
835 $line->qty = $objp->qty;
836 $line->remise_percent = $objp->remise_percent;
837 $line->fk_remise_except = $objp->fk_remise_except;
838 $line->vat_src_code = $objp->vat_src_code;
839 $line->tva_tx = $objp->tva_tx;
840 $line->localtax1_tx = $objp->localtax1_tx;
841 $line->localtax1_type = $objp->localtax1_type;
842 $line->localtax2_tx = $objp->localtax2_tx;
843 $line->localtax2_type = $objp->localtax2_type;
844 $line->total_ht = $objp->total_ht;
845 $line->total_tva = $objp->total_tva;
846 $line->total_localtax1 = $objp->total_localtax1;
847 $line->total_localtax2 = $objp->total_localtax2;
848 $line->total_ttc = $objp->total_ttc;
849 $line->product_type = $objp->product_type;
850 $line->date_start = $objp->date_start;
851 $line->date_end = $objp->date_end;
852 $line->info_bits = $objp->info_bits ;
853 $line->special_code = $objp->special_code;
854 $line->rang = $objp->rang;
855 $line->fk_unit = $objp->fk_unit;
856 $line->import_key = $objp->import_key;
857 $line->fk_user_author = $objp->fk_user_author;
858 $line->fk_user_modif = $objp->fk_user_modif;
859 $line->fk_multicurrency = $objp->fk_multicurrency;
860 $line->multicurrency_code = $objp->multicurrency_code;
861 $line->multicurrency_subprice = $objp->multicurrency_subprice;
862 $line->multicurrency_total_ht = $objp->multicurrency_total_ht;
863 $line->multicurrency_total_tva = $objp->multicurrency_total_tva;
864 $line->multicurrency_total_ttc = $objp->multicurrency_total_ttc;
866 $line->fetch_optionals();
868 $this->lines[$i] = $line;
873 $this->db->free($result);
876 $this->error = $this->db->lasterror();
890 public function delete(
User $user, $notrigger = 0, $idwarehouse = -1)
894 dol_syslog(get_class($this).
"::delete rowid=".((
int) $rowid), LOG_DEBUG);
899 $main = MAIN_DB_PREFIX.
'facture_fourn_det_rec';
900 $ef = $main.
"_extrafields";
902 $sqlef =
"DELETE FROM ".$ef.
" WHERE fk_object IN (SELECT rowid FROM ".$main.
" WHERE fk_facture_fourn = ". (int) $rowid .
")";
903 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"facture_fourn_det_rec WHERE fk_facture_fourn = ". (int) $rowid;
905 if ($this->db->query($sqlef) && $this->db->query($sql)) {
906 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"facture_fourn_rec WHERE rowid = ". (int) $rowid;
908 if ($this->db->query($sql)) {
920 $this->error = $this->db->lasterror();
924 $this->error = $this->db->lasterror();
927 if (!$error && !$notrigger) {
929 $result = $this->
call_trigger(
'SUPPLIERBILLREC_DELETE', $user);
939 $this->db->rollback();
970 public function addline($fk_product, $ref, $label, $desc, $pu_ht, $pu_ttc, $qty, $remise_percent, $txtva, $txlocaltax1 = 0, $txlocaltax2 = 0, $price_base_type =
'HT', $type = 0, $date_start = 0, $date_end = 0, $info_bits = 0, $special_code = 0, $rang = -1, $fk_unit =
null, $pu_ht_devise = 0)
972 global $mysoc, $user;
974 include_once DOL_DOCUMENT_ROOT.
'/core/lib/price.lib.php';
978 dol_syslog(get_class($this).
"::addline facid=$facid,desc=$desc,pu_ht=$pu_ht,qty=$qty,txtva=$txtva,txlocaltax1=$txlocaltax1,txlocaltax2=$txlocaltax2,fk_product=$fk_product,remise_percent=$remise_percent,info_bits=$info_bits,price_base_type=$price_base_type,pu_ttc=$pu_ttc,type=$type,fk_unit=$fk_unit,pu_ht_devise=$pu_ht_devise,date_start_fill=$date_start,date_end_fill=$date_end", LOG_DEBUG);
985 if ($this->suspended == self::STATUS_NOTSUSPENDED) {
991 if (preg_match(
'/\((.*)\)/', (
string) $txtva, $reg)) {
992 $vat_src_code = $reg[1];
993 $txtva = preg_replace(
'/\s*\(.*\)/',
'', (
string) $txtva);
997 $fk_product = empty($fk_product) ? 0 : $fk_product;
998 $label = empty($label) ?
'' : $label;
999 $remise_percent = empty($remise_percent) ? 0 :
price2num($remise_percent);
1003 if (!preg_match(
'/\((.*)\)/', $txtva)) {
1008 $txtva = !empty($txtva) ? $txtva : 0;
1009 $txlocaltax1 = !empty($txlocaltax1) ? $txlocaltax1 : 0;
1010 $txlocaltax2 = !empty($txlocaltax2) ? $txlocaltax2 : 0;
1011 $info_bits = !empty($info_bits) ? $info_bits : 0;
1012 $info_bits = !empty($info_bits) ? $info_bits : 0;
1013 $pu = $price_base_type ==
'HT' ? $pu_ht : $pu_ttc;
1019 $tabprice =
calcul_price_total($qty, $pu, $remise_percent, $txtva, $txlocaltax1, $txlocaltax2, 0, $price_base_type, $info_bits, $type, $mysoc, $localtaxes_type, 100, $this->multicurrency_tx, $pu_ht_devise);
1020 $total_ht = $tabprice[0];
1021 $total_tva = $tabprice[1];
1022 $total_ttc = $tabprice[2];
1023 $total_localtax1 = $tabprice[9];
1024 $total_localtax2 = $tabprice[10];
1025 $pu_ht = $tabprice[3];
1028 $multicurrency_total_ht = $tabprice[16];
1029 $multicurrency_total_tva = $tabprice[17];
1030 $multicurrency_total_ttc = $tabprice[18];
1031 $pu_ht_devise = $tabprice[19];
1034 $product_type = $type;
1036 $product =
new Product($this->db);
1037 $result = $product->fetch($fk_product);
1041 $product_type = $product->type;
1042 if (empty($label)) {
1043 $label = $product->label;
1047 $sql =
'INSERT INTO ' . MAIN_DB_PREFIX .
'facture_fourn_det_rec (';
1048 $sql .=
'fk_facture_fourn';
1049 $sql .=
', fk_product';
1052 $sql .=
', description';
1056 $sql .=
', remise_percent';
1057 $sql .=
', fk_remise_except';
1058 $sql .=
', vat_src_code';
1060 $sql .=
', localtax1_tx';
1061 $sql .=
', localtax1_type';
1062 $sql .=
', localtax2_tx';
1063 $sql .=
', localtax2_type';
1064 $sql .=
', total_ht';
1065 $sql .=
', total_tva';
1066 $sql .=
', total_localtax1';
1067 $sql .=
', total_localtax2';
1068 $sql .=
', total_ttc';
1069 $sql .=
', product_type';
1070 $sql .=
', date_start';
1071 $sql .=
', date_end';
1072 $sql .=
', info_bits';
1073 $sql .=
', special_code';
1075 $sql .=
', fk_unit';
1076 $sql .=
', fk_user_author';
1077 $sql .=
', fk_multicurrency, multicurrency_code, multicurrency_subprice, multicurrency_total_ht, multicurrency_total_tva, multicurrency_total_ttc';
1078 $sql .=
') VALUES (';
1079 $sql .=
' ' . (int) $facid;
1080 $sql .=
', ' . (!empty($fk_product) ?
"'" . $this->db->escape($fk_product) .
"'" :
'null');
1081 $sql .=
', ' . (!empty($ref) ?
"'" . $this->db->escape($ref) .
"'" :
'null');
1082 $sql .=
', ' . (!empty($label) ?
"'" . $this->db->escape($label) .
"'" :
'null');
1083 $sql .=
", '" . $this->db->escape($desc) .
"'";
1087 $sql .=
', ' .
price2num($remise_percent);
1089 $sql .=
", '" . $this->db->escape($vat_src_code) .
"'";
1092 $sql .=
", '" . $this->db->escape(isset($localtaxes_type[0]) ? $localtaxes_type[0] :
'') .
"'";
1094 $sql .=
", '" . $this->db->escape(isset($localtaxes_type[2]) ? $localtaxes_type[2] :
'') .
"'";
1097 $sql .=
', ' .
price2num($total_localtax1);
1098 $sql .=
', ' .
price2num($total_localtax2);
1100 $sql .=
', ' . (int) $product_type;
1101 $sql .=
', ' . ($date_start > 0 ? (int) $date_start :
'NULL');
1102 $sql .=
', ' . ($date_end > 0 ? (int) $date_end :
'NULL');
1103 $sql .=
', ' . (int) $info_bits;
1104 $sql .=
', ' . (int) $special_code;
1105 $sql .=
', ' . (int) $rang;
1106 $sql .=
', ' . ($fk_unit ? (int) $fk_unit :
'NULL');
1107 $sql .=
', ' . (int) $user->id;
1108 $sql .=
', ' . (int) $this->fk_multicurrency;
1109 $sql .=
", '" . $this->db->escape($this->multicurrency_code) .
"'";
1110 $sql .=
', ' .
price2num($pu_ht_devise,
'CU');
1111 $sql .=
', ' .
price2num($multicurrency_total_ht,
'CT');
1112 $sql .=
', ' .
price2num($multicurrency_total_tva,
'CT');
1113 $sql .=
', ' .
price2num($multicurrency_total_ttc,
'CT');
1116 dol_syslog(get_class($this).
'::addline', LOG_DEBUG);
1117 if ($this->db->query($sql)) {
1118 $lineId = $this->db->last_insert_id(MAIN_DB_PREFIX.
'facture_fourn_det_rec');
1121 $this->db->commit();
1124 $this->db->rollback();
1125 $this->error = $this->db->lasterror();
1130 $this->error =
'Recurring Invoice is suspended. adding lines not allowed.';
1163 public function updateline($rowid, $fk_product, $ref, $label, $desc, $pu_ht, $qty, $remise_percent, $txtva, $txlocaltax1 = 0, $txlocaltax2 = 0, $price_base_type =
'HT', $type = 0, $date_start = 0, $date_end = 0, $info_bits = 0, $special_code = 0, $rang = -1, $fk_unit =
null, $pu_ht_devise = 0, $pu_ttc = 0)
1165 global $mysoc, $user;
1169 dol_syslog(get_class($this).
'::updateline facid=' .$facid.
" rowid=$rowid, desc=$desc, pu_ht=$pu_ht, qty=$qty, txtva=$txtva, txlocaltax1=$txlocaltax1, txlocaltax2=$txlocaltax2, fk_product=$fk_product, remise_percent=$remise_percent, info_bits=$info_bits, price_base_type=$price_base_type, pu_ttc=$pu_ttc, type=$type, fk_unit=$fk_unit, pu_ht_devise=$pu_ht_devise", LOG_DEBUG);
1170 include_once DOL_DOCUMENT_ROOT.
'/core/lib/price.lib.php';
1177 if ($this->
status == self::STATUS_SUSPENDED) {
1179 $fk_product = empty($fk_product) ? 0 : $fk_product;
1180 $label = empty($label) ?
'' : $label;
1181 $remise_percent = empty($remise_percent) ? 0 :
price2num($remise_percent);
1183 $info_bits = empty($info_bits) ? 0 : $info_bits;
1186 $pu_ht_devise =
price2num($pu_ht_devise);
1188 if (!preg_match(
'/\((.*)\)/', (
string) $txtva)) {
1192 $txlocaltax1 = empty($txlocaltax1) ? 0 :
price2num($txlocaltax1);
1193 $txlocaltax2 = empty($txlocaltax2) ? 0 :
price2num($txlocaltax2);
1194 $this->multicurrency_total_ht = empty($this->multicurrency_total_ht) ? 0 : $this->multicurrency_total_ht;
1195 $this->multicurrency_total_tva = empty($this->multicurrency_total_tva) ? 0 : $this->multicurrency_total_tva;
1196 $this->multicurrency_total_ttc = empty($this->multicurrency_total_ttc) ? 0 : $this->multicurrency_total_ttc;
1198 $pu = $price_base_type ==
'HT' ? $pu_ht : $pu_ttc;
1210 if (preg_match(
'/\((.*)\)/', $txtva, $reg)) {
1211 $vat_src_code = $reg[1];
1212 $txtva = preg_replace(
'/\s*\(.*\)/',
'', $txtva);
1215 $tabprice =
calcul_price_total($qty, $pu, $remise_percent, $txtva, $txlocaltax1, $txlocaltax2, 0, $price_base_type, $info_bits, $type, $mysoc, $localtaxes_type, 100, $this->multicurrency_tx, $pu_ht_devise);
1217 $total_ht = $tabprice[0];
1218 $total_tva = $tabprice[1];
1219 $total_ttc = $tabprice[2];
1220 $total_localtax1 = $tabprice[9];
1221 $total_localtax2 = $tabprice[10];
1222 $pu_ht = $tabprice[3];
1223 $pu_tva = $tabprice[4];
1224 $pu_ttc = $tabprice[5];
1227 $multicurrency_total_ht = $tabprice[16];
1228 $multicurrency_total_tva = $tabprice[17];
1229 $multicurrency_total_ttc = $tabprice[18];
1230 $pu_ht_devise = $tabprice[19];
1232 $product_type = $type;
1234 $product =
new Product($this->db);
1235 $result = $product->fetch($fk_product);
1236 $product_type = $product->type;
1239 $sql =
'UPDATE ' . MAIN_DB_PREFIX .
'facture_fourn_det_rec SET';
1240 $sql .=
' fk_facture_fourn = ' . ((int) $facid);
1241 $sql .=
', fk_product = ' . ($fk_product > 0 ? ((int) $fk_product) :
'null');
1242 $sql .=
", ref = '" . $this->db->escape($ref) .
"'";
1243 $sql .=
", label = '" . $this->db->escape($label) .
"'";
1244 $sql .=
", description = '" . $this->db->escape($desc) .
"'";
1245 $sql .=
', pu_ht = ' .
price2num($pu_ht);
1247 $sql .=
", remise_percent = '" .
price2num($remise_percent) .
"'";
1248 $sql .=
", vat_src_code = '" . $this->db->escape($vat_src_code) .
"'";
1249 $sql .=
', tva_tx = ' .
price2num($txtva);
1250 $sql .=
', localtax1_tx = ' . (float) $txlocaltax1;
1251 $sql .=
", localtax1_type = '" . $this->db->escape($localtaxes_type[0]) .
"'";
1252 $sql .=
', localtax2_tx = ' . (float) $txlocaltax2;
1253 $sql .=
", localtax2_type = '" . $this->db->escape($localtaxes_type[2]) .
"'";
1254 $sql .=
", total_ht = '" .
price2num($total_ht) .
"'";
1255 $sql .=
", total_tva = '" .
price2num($total_tva) .
"'";
1256 $sql .=
", total_localtax1 = '" .
price2num($total_localtax1) .
"'";
1257 $sql .=
", total_localtax2 = '" .
price2num($total_localtax2) .
"'";
1258 $sql .=
", total_ttc = '" .
price2num($total_ttc) .
"'";
1259 $sql .=
', product_type = ' . (int) $product_type;
1260 $sql .=
', date_start = ' . (empty($date_start) ?
'NULL' : (int) $date_start);
1261 $sql .=
', date_end = ' . (empty($date_end) ?
'NULL' : (int) $date_end);
1262 $sql .=
', info_bits = ' . (int) $info_bits;
1263 $sql .=
', special_code = ' . (int) $special_code;
1264 $sql .=
', rang = ' . (int) $rang;
1265 $sql .=
', fk_unit = ' . ($fk_unit ?
"'" . $this->db->escape($fk_unit) .
"'" :
'null');
1266 $sql .=
', fk_user_modif = ' . (int) $user;
1267 $sql .=
', multicurrency_subprice = '.price2num($pu_ht_devise);
1268 $sql .=
', multicurrency_total_ht = '.price2num($multicurrency_total_ht);
1269 $sql .=
', multicurrency_total_tva = '.price2num($multicurrency_total_tva);
1270 $sql .=
', multicurrency_total_ttc = '.price2num($multicurrency_total_ttc);
1271 $sql .=
' WHERE rowid = ' . (int) $rowid;
1273 dol_syslog(get_class($this).
'::updateline', LOG_DEBUG);
1274 if ($this->db->query($sql)) {
1279 $this->error = $this->db->lasterror();
1307 if (empty($this->date_when)) {
1310 return dol_time_plus_duree((
int) $this->date_when, $this->frequency, $this->unit_frequency);
1321 if ($this->nb_gen_max > 0 && ($this->nb_gen_done >= $this->nb_gen_max)) {
1336 return ($this->
isMaxNbGenReached() ?
'<strike>' :
'').$ret.($this->isMaxNbGenReached() ?
'</strike>' :
'');
1351 global $conf, $langs, $db, $user, $hookmanager;
1357 $langs->loadLangs(array(
'main',
'bills'));
1361 $today =
dol_mktime(23, 59, 59, $tmparray[
'mon'], $tmparray[
'mday'], $tmparray[
'year']);
1363 dol_syslog(
'createRecurringInvoices restrictioninvoiceid=' .$restrictioninvoiceid.
' forcevalidation=' .$forcevalidation);
1365 $sql =
'SELECT rowid FROM '.MAIN_DB_PREFIX.
'facture_fourn_rec';
1366 $sql .=
' WHERE frequency > 0';
1367 $sql .=
" AND (date_when IS NULL OR date_when <= '".$this->db->idate($today).
"')";
1368 $sql .=
' AND (nb_gen_done < nb_gen_max OR nb_gen_max = 0)';
1369 $sql .=
' AND suspended = 0';
1370 $sql .=
' AND entity = '. (int) $conf->entity;
1371 if ($restrictioninvoiceid > 0) {
1372 $sql .=
' AND rowid = '. (int) $restrictioninvoiceid;
1374 $sql .= $this->db->order(
'entity',
'ASC');
1376 $parameters = array(
1377 'restrictioninvoiceid' => $restrictioninvoiceid,
1378 'forcevalidation' => $forcevalidation,
1380 $reshook = $hookmanager->executeHooks(
'beforeCreationOfRecurringInvoices', $parameters, $sql);
1382 $resql = $this->db->query($sql);
1385 $num = $this->db->num_rows($resql);
1388 $this->output .= $langs->trans(
'FoundXQualifiedRecurringInvoiceTemplate', $num).
"\n";
1390 $this->output .= $langs->trans(
'NoQualifiedRecurringInvoiceTemplateFound');
1393 $saventity = $conf->entity;
1397 $line = $this->db->fetch_object($resql);
1401 $invoiceidgenerated = 0;
1403 $new_fac_fourn =
null;
1405 $laststep =
"Fetch {$line->rowid}";
1406 $facturerec->fetch($line->rowid);
1408 if ($facturerec->id > 0) {
1410 $conf->entity = $facturerec->entity;
1412 dol_syslog(
'createRecurringInvoices Process invoice template id=' .$facturerec->id.
', ref=' .$facturerec->ref.
', entity=' .$facturerec->entity);
1415 $new_fac_fourn->fac_rec = $facturerec->id;
1416 $new_fac_fourn->fk_fac_rec_source = $facturerec->id;
1419 $new_fac_fourn->subtype = $facturerec->subtype;
1422 $new_fac_fourn->date = empty($facturerec->date_when) ? $now : $facturerec->date_when;
1423 $new_fac_fourn->socid = $facturerec->socid;
1424 $new_fac_fourn->lines = $facturerec->lines;
1425 $new_fac_fourn->ref_supplier = $facturerec->ref_supplier;
1426 $new_fac_fourn->model_pdf = $facturerec->model_pdf;
1427 $new_fac_fourn->fk_project = $facturerec->fk_project;
1428 $new_fac_fourn->label = $facturerec->label;
1429 $new_fac_fourn->libelle = $facturerec->label;
1431 $invoiceidgenerated = $new_fac_fourn->create($user);
1432 $laststep =
"Create invoiceidgenerated $invoiceidgenerated";
1433 if ($invoiceidgenerated <= 0) {
1434 $this->errors = $new_fac_fourn->errors;
1435 $this->error = $new_fac_fourn->error;
1438 if (!$error && ($facturerec->auto_validate || $forcevalidation)) {
1439 $result = $new_fac_fourn->validate($user);
1440 $laststep =
"Validate by user {$user->login}";
1442 $this->errors = $new_fac_fourn->errors;
1443 $this->error = $new_fac_fourn->error;
1448 if (!$error && $facturerec->generate_pdf) {
1450 $laststep =
"Refresh ".$new_fac_fourn->id;
1451 $new_fac_fourn->fetch($new_fac_fourn->id);
1452 $laststep =
"GenerateDocument ".$new_fac_fourn->id;
1453 $result = $new_fac_fourn->generateDocument($facturerec->model_pdf, $langs);
1455 $this->errors = $new_fac_fourn->errors;
1456 $this->error = $new_fac_fourn->error;
1462 $this->error =
'Failed to load invoice template with id=' .$line->rowid.
', entity=' .$conf->entity.
"\n";
1463 $this->errors[] =
'Failed to load invoice template with id=' .$line->rowid.
', entity=' .$conf->entity;
1464 dol_syslog(
'createRecurringInvoices Failed to load invoice template with id=' .$line->rowid.
', entity=' .$conf->entity);
1467 if (!$error && $invoiceidgenerated >= 0) {
1468 $facturerec->nb_gen_done++;
1469 $facturerec->date_last_gen =
dol_now();
1470 $nextDate = $facturerec->getNextDate();
1471 $facturerec->date_when = (($nextDate ===
false) ?
null : $nextDate);
1472 $facturerec->update($user);
1473 $this->db->commit(
'createRecurringInvoices Process invoice template id=' .$facturerec->id.
', title=' .$facturerec->title);
1474 dol_syslog(
'createRecurringInvoices Process invoice template ' .$facturerec->title.
' is finished with a success generation');
1476 $this->output .= $langs->trans(
'InvoiceGeneratedFromTemplate', $new_fac_fourn->ref, $facturerec->title).
"\n";
1478 $this->db->rollback(
'createRecurringInvoices Process invoice template error='.$error.
' invoiceidgenerated='.$invoiceidgenerated.
' LastStep='.$laststep.
' id=' .$facturerec->id.
', title=' .$facturerec->title);
1481 $parameters = array(
1484 'errorCount' => $error,
1485 'invoiceidgenerated' => $invoiceidgenerated,
1486 'facturerec' => $facturerec,
1489 $reshook = $hookmanager->executeHooks(
'afterCreationOfRecurringInvoice', $parameters, $new_fac_fourn);
1494 $conf->entity = $saventity;
1499 $this->output = trim($this->output);
1501 return $error ? $error : 0;
1516 public function getNomUrl($withpicto = 0, $option =
'', $max = 0, $short = 0, $moretitle =
'', $notooltip = 0, $save_lastsearch_value = -1)
1518 global $langs, $hookmanager;
1522 $label =
'<u>'.$langs->trans(
'RepeatableInvoice').
'</u>';
1523 if (!empty($this->
ref)) {
1524 $label .=
'<br><b>'.$langs->trans(
'Ref').
':</b> '.$this->ref;
1526 if ($this->frequency > 0) {
1527 $label .=
'<br><b>'.$langs->trans(
'Frequency').
':</b> '.$langs->trans(
'FrequencyPer_'.$this->unit_frequency, $this->frequency);
1529 if (!empty($this->date_last_gen)) {
1530 $label .=
'<br><b>'.$langs->trans(
'DateLastGeneration').
':</b> '.
dol_print_date($this->date_last_gen,
'dayhour');
1532 if ($this->frequency > 0) {
1533 if (!empty($this->date_when)) {
1534 $label .=
'<br><b>'.$langs->trans(
'NextDateToExecution').
':</b> ';
1535 $label .= (empty($this->suspended) ?
'' :
'<strike>').
dol_print_date($this->date_when,
'day').(empty($this->suspended) ?
'' :
'</strike>');
1536 if (!empty($this->suspended)) {
1537 $label .=
' ('.$langs->trans(
'Disabled').
')';
1542 $url = DOL_URL_ROOT.
'/fourn/facture/card-rec.php?facid='.$this->id;
1548 if ($option !=
'nolink') {
1550 $add_save_lastsearch_values = ($save_lastsearch_value == 1 ? 1 : 0);
1551 if ($save_lastsearch_value == -1 && preg_match(
'/list\.php/', $_SERVER[
'PHP_SELF'])) {
1552 $add_save_lastsearch_values = 1;
1554 if ($add_save_lastsearch_values) {
1555 $url .=
'&save_lastsearch_values=1';
1559 $linkstart =
'<a href="'.$url.
'" title="'.
dol_escape_htmltag($label, 1).
'" class="classfortooltip">';
1562 $result .= $linkstart;
1564 $result .=
img_object(($notooltip ?
'' : $label), ($this->picto ? $this->picto :
'generic'), ($notooltip ? (($withpicto != 2) ?
'class="paddingright"' :
'') :
'class="'.(($withpicto != 2) ?
'paddingright ' :
'').
'classfortooltip"'), 0, 0, $notooltip ? 0 : 1);
1566 if ($withpicto != 2) {
1567 $result .= $this->ref;
1569 $result .= $linkend;
1571 $hookmanager->initHooks(array($this->element .
'dao'));
1572 $parameters = array(
'id' => $this->
id,
'getnomurl' => &$result);
1573 $reshook = $hookmanager->executeHooks(
'getNomUrl', $parameters, $this, $action);
1575 $result = $hookmanager->resPrint;
1577 $result .= $hookmanager->resPrint;
1591 return $this->
LibStatut($this->frequency ? 1 : 0, $this->suspended, $mode, $alreadypaid, empty($this->
type) ? 0 : $this->type);
1605 public function LibStatut($recur, $status, $mode = 0, $alreadypaid = -1, $type = 0)
1609 $langs->load(
'bills');
1611 $labelStatus = $langs->transnoentitiesnoconv(
'Active');
1612 $statusType =
'status0';
1617 if ($status == self::STATUS_SUSPENDED) {
1618 $labelStatus = $langs->transnoentitiesnoconv(
'Disabled');
1620 $labelStatus = $langs->transnoentitiesnoconv(
'Active');
1623 if ($status == self::STATUS_SUSPENDED) {
1624 $labelStatus = $langs->transnoentitiesnoconv(
'Disabled');
1626 $labelStatus = $langs->transnoentitiesnoconv(
'Draft');
1629 } elseif ($mode == 1) {
1632 if ($status == self::STATUS_SUSPENDED) {
1633 $labelStatus = $langs->transnoentitiesnoconv(
'Disabled');
1635 $labelStatus = $langs->transnoentitiesnoconv(
'Active');
1638 if ($status == self::STATUS_SUSPENDED) {
1639 $labelStatus = $langs->transnoentitiesnoconv(
'Disabled');
1641 $labelStatus = $langs->transnoentitiesnoconv(
'Draft');
1644 } elseif ($mode == 2) {
1646 if ($status == self::STATUS_SUSPENDED) {
1647 $statusType =
'status6';
1648 $labelStatus = $langs->transnoentitiesnoconv(
'Disabled');
1650 $statusType =
'status4';
1651 $labelStatus = $langs->transnoentitiesnoconv(
'Active');
1654 if ($status == self::STATUS_SUSPENDED) {
1655 $statusType =
'status6';
1656 $labelStatus = $langs->transnoentitiesnoconv(
'Disabled');
1658 $statusType =
'status0';
1659 $labelStatus = $langs->transnoentitiesnoconv(
'Draft');
1662 } elseif ($mode == 3) {
1665 if ($status == self::STATUS_SUSPENDED) {
1666 $statusType =
'status6';
1667 $labelStatus = $langs->transnoentitiesnoconv(
'Disabled');
1669 $statusType =
'status4';
1670 $labelStatus = $langs->transnoentitiesnoconv(
'Active');
1673 if ($status == self::STATUS_SUSPENDED) {
1674 $statusType =
'status6';
1675 $labelStatus = $langs->transnoentitiesnoconv(
'Disabled');
1677 $statusType =
'status0';
1678 $labelStatus = $langs->transnoentitiesnoconv(
'Draft');
1681 } elseif ($mode == 4) {
1684 if ($status == self::STATUS_SUSPENDED) {
1685 $statusType =
'status6';
1686 $labelStatus = $langs->transnoentitiesnoconv(
'Disabled');
1688 $statusType =
'status4';
1689 $labelStatus = $langs->transnoentitiesnoconv(
'Active');
1692 if ($status == self::STATUS_SUSPENDED) {
1693 $statusType =
'status6';
1694 $labelStatus = $langs->transnoentitiesnoconv(
'Disabled');
1696 $statusType =
'status0';
1697 $labelStatus = $langs->transnoentitiesnoconv(
'Draft');
1700 } elseif ($mode == 5 || $mode == 6) {
1706 if ($status == self::STATUS_SUSPENDED) {
1707 $statusType =
'status6';
1708 $labelStatus = $langs->transnoentitiesnoconv(
'Disabled');
1710 $statusType =
'status4';
1711 $labelStatus = $langs->transnoentitiesnoconv(
'Active');
1714 if ($status == self::STATUS_SUSPENDED) {
1715 $statusType =
'status6';
1716 $labelStatus = $langs->transnoentitiesnoconv(
'Disabled');
1718 $statusType =
'status0';
1719 $labelStatus = $langs->transnoentitiesnoconv(
'Draft');
1724 $labelStatusShort = $labelStatus;
1726 return dolGetStatus($labelStatus, $labelStatusShort,
'', $statusType, $mode);
1739 global $user, $langs, $conf;
1743 $nownotime =
dol_mktime(0, 0, 0, $arraynow[
'mon'], $arraynow[
'mday'], $arraynow[
'year']);
1749 $sql =
'SELECT rowid';
1750 $sql .=
' FROM ' .MAIN_DB_PREFIX.
'product';
1751 $sql .=
' WHERE entity IN (' .getEntity(
'product').
')';
1752 $sql .= $this->db->plimit(100);
1754 $resql = $this->db->query($sql);
1756 $num_prods = $this->db->num_rows($resql);
1758 while ($i < $num_prods) {
1760 $row = $this->db->fetch_row($resql);
1761 $prodids[$i] = $row[0];
1767 $this->
ref =
'SPECIMEN';
1768 $this->title =
'SPECIMEN';
1769 $this->specimen = 1;
1771 $this->date = $nownotime;
1772 $this->date_lim_reglement = $nownotime + 3600 * 24 * 30;
1773 $this->cond_reglement_id = 1;
1774 $this->cond_reglement_code =
'RECEP';
1776 $this->mode_reglement_id = 0;
1777 $this->mode_reglement_code =
'';
1778 $this->note_public =
'This is a comment (public)';
1779 $this->note_private =
'This is a comment (private)';
1780 $this->note =
'This is a comment (private)';
1781 $this->fk_incoterms = 0;
1782 $this->location_incoterms =
'';
1784 if (empty($option) || $option !=
'nolines') {
1788 while ($xnbp < $nbp) {
1790 $line->desc = $langs->trans(
'Description').
' ' .$xnbp;
1792 $line->subprice = 100;
1793 $line->tva_tx = 19.6;
1794 $line->localtax1_tx = 0;
1795 $line->localtax2_tx = 0;
1796 $line->remise_percent = 0;
1798 $prodid = mt_rand(1, $num_prods);
1799 $line->fk_product = $prodids[$prodid];
1801 $line->total_ht = -100;
1802 $line->total_ttc = -119.6;
1803 $line->total_tva = -19.6;
1804 } elseif ($xnbp == 2) {
1805 $line->subprice = -100;
1806 $line->total_ht = -100;
1807 $line->total_ttc = -119.6;
1808 $line->total_tva = -19.6;
1809 $line->remise_percent = 0;
1810 } elseif ($xnbp == 3) {
1811 $prodid = mt_rand(1, $num_prods);
1812 $line->fk_product = $prodids[$prodid];
1813 $line->total_ht = 50;
1814 $line->total_ttc = 59.8;
1815 $line->total_tva = 9.8;
1816 $line->remise_percent = 50;
1818 $prodid = mt_rand(1, $num_prods);
1819 $line->fk_product = $prodids[$prodid];
1820 $line->total_ht = 100;
1821 $line->total_ttc = 119.6;
1822 $line->total_tva = 19.6;
1823 $line->remise_percent = 00;
1826 $this->lines[$xnbp] = $line;
1829 $this->total_ht += $line->total_ht;
1830 $this->total_tva += $line->total_tva;
1831 $this->total_ttc += $line->total_ttc;
1833 $this->revenuestamp = 0;
1837 $line->desc = $langs->trans(
'Description').
' (offered line)';
1839 $line->subprice = 100;
1840 $line->tva_tx = 19.6;
1841 $line->localtax1_tx = 0;
1842 $line->localtax2_tx = 0;
1843 $line->remise_percent = 100;
1844 $line->total_ht = 0;
1845 $line->total_ttc = 0;
1846 $line->total_tva = 0;
1847 $prodid = mt_rand(1, $num_prods);
1848 $line->fk_product = $prodids[$prodid];
1850 $this->lines[$xnbp] = $line;
1854 $this->usenewprice = 0;
1885 if (!$this->table_element) {
1886 dol_syslog(get_class($this).
'::setFrequencyAndUnit was called on object with property table_element not defined', LOG_ERR);
1890 if (!empty($frequency) && empty($unit)) {
1891 dol_syslog(get_class($this).
'::setFrequencyAndUnit was called on object with params frequency defined but unit not defined', LOG_ERR);
1895 $sql =
"UPDATE ".MAIN_DB_PREFIX.$this->table_element;
1896 $sql .=
" SET frequency = ".($frequency ? ((int) $frequency) :
"NULL");
1897 if (!empty($unit)) {
1898 $sql .=
", unit_frequency = '".$this->db->escape($unit).
"'";
1900 $sql .=
" WHERE rowid = ".((int) $this->
id);
1902 dol_syslog(get_class($this).
'::setFrequencyAndUnit', LOG_DEBUG);
1904 if ($this->db->query($sql)) {
1905 $this->frequency = $frequency;
1906 if (!empty($unit)) {
1907 $this->unit_frequency = $unit;
1911 $this->error = $this->db->lasterror();
1925 if (!$this->table_element) {
1926 dol_syslog(get_class($this).
'::setNextDate was called on object with property table_element not defined', LOG_ERR);
1929 $sql =
"UPDATE ".MAIN_DB_PREFIX.$this->table_element;
1930 $sql .=
" SET date_when = " .($date ?
"'".$this->db->idate($date).
"'" :
"NULL");
1931 if ($increment_nb_gen_done > 0) {
1932 $sql .=
", nb_gen_done = nb_gen_done + 1";
1934 $sql .=
" WHERE rowid = " . (int) $this->
id;
1936 dol_syslog(get_class($this).
'::setNextDate', LOG_DEBUG);
1938 if ($this->db->query($sql)) {
1939 $this->date_when = $date;
1940 if ($increment_nb_gen_done > 0) {
1941 $this->nb_gen_done++;
1945 $this->error = $this->db->lasterror();
1958 if (!$this->table_element) {
1959 dol_syslog(get_class($this).
'::setMaxPeriod was called on object with property table_element not defined', LOG_ERR);
1967 $sql =
"UPDATE ".MAIN_DB_PREFIX.$this->table_element;
1968 $sql .=
" SET nb_gen_max = ". (int) $nb;
1969 $sql .=
" WHERE rowid = " . (int) $this->
id;
1971 dol_syslog(get_class($this).
'::setMaxPeriod', LOG_DEBUG);
1973 if ($this->db->query($sql)) {
1974 $this->nb_gen_max = $nb;
1990 if (!$this->table_element) {
1991 dol_syslog(get_class($this).
'::setAutoValidate was called on object with property table_element not defined', LOG_ERR);
1995 $sql =
"UPDATE ".MAIN_DB_PREFIX.$this->table_element;
1996 $sql .=
" SET auto_validate = ".((int) $validate);
1997 $sql .=
" WHERE rowid = " . (int) $this->
id;
1999 dol_syslog(get_class($this).
'::setAutoValidate', LOG_DEBUG);
2001 if ($this->db->query($sql)) {
2002 $this->auto_validate = $validate;
2018 if (!$this->table_element) {
2019 dol_syslog(get_class($this).
'::setGeneratePdf was called on object with property table_element not defined', LOG_ERR);
2023 $sql =
"UPDATE ".MAIN_DB_PREFIX.$this->table_element;
2024 $sql .=
" SET generate_pdf = ". (int) $validate;
2025 $sql .=
" WHERE rowid = " . (int) $this->
id;
2027 dol_syslog(get_class($this).
'::setGeneratePdf', LOG_DEBUG);
2029 if ($this->db->query($sql)) {
2030 $this->generate_pdf = $validate;
2046 if (!$this->table_element) {
2047 dol_syslog(get_class($this).
'::setModelPdf was called on object with property table_element not defined', LOG_ERR);
2051 $sql =
"UPDATE ".MAIN_DB_PREFIX.$this->table_element;
2052 $sql .=
" SET modelpdf = '".$this->db->escape($model).
"'";
2053 $sql .=
" WHERE rowid = " . (int) $this->
id;
2055 dol_syslog(get_class($this).
'::setModelPdf', LOG_DEBUG);
2057 if ($this->db->query($sql)) {
2058 $this->model_pdf = $model;
Superclass for invoice classes.
const TYPE_STANDARD
Standard invoice.
calculate_date_lim_reglement($cond_reglement=0)
Returns an invoice payment deadline based on the invoice settlement conditions and billing date.
const STATUS_DRAFT
Draft status.
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...
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.
deleteObjectLinked($sourceid=null, $sourcetype='', $targetid=null, $targettype='', $rowid=0, $f_user=null, $notrigger=0)
Delete all links between an object $this.
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.
insertExtraFields($trigger='', $userused=null)
Add/Update all extra fields values for the current object.
call_trigger($triggerName, $user)
Call trigger based on this instance.
Class to manage Dolibarr database access.
Class to manage suppliers invoices.
Class to manage supplier invoice lines of templates.
Class to manage invoice templates.
setModelPdf($model)
Update the model for documents.
fetch($rowid, $ref='', $ref_ext='')
Load object and lines.
strikeIfMaxNbGenReached($ret)
Format string to output with by striking the string if max number of generation was reached.
setFrequencyAndUnit($frequency, $unit)
Update frequency and unit.
getNextNumRef($soc, $mode='next')
Return next reference of invoice not already used (or last reference)
create($user, $facFournId, $notrigger=0)
Create a predefined supplier invoice.
setGeneratePdf($validate)
Update the auto generate documents.
getLinesArray()
Create an array of invoice lines.
initAsSpecimen($option='')
Initialise an instance with random values.
LibStatut($recur, $status, $mode=0, $alreadypaid=-1, $type=0)
Return label of a status.
updateline($rowid, $fk_product, $ref, $label, $desc, $pu_ht, $qty, $remise_percent, $txtva, $txlocaltax1=0, $txlocaltax2=0, $price_base_type='HT', $type=0, $date_start=0, $date_end=0, $info_bits=0, $special_code=0, $rang=-1, $fk_unit=null, $pu_ht_devise=0, $pu_ttc=0)
Update a line to supplier invoice template.
isMaxNbGenReached()
Return if maximum number of generation is reached.
setAutoValidate($validate)
Update the auto validate flag of invoice.
static replaceThirdparty(DoliDB $dbs, $origin_id, $dest_id)
Function used to replace a thirdparty id with another one.
getNextDate()
Return the next date of.
__construct($db)
Constructor.
fetch_lines()
Get lines of template invoices into this->lines.
getLibStatut($mode=0, $alreadypaid=-1)
Return label of object status.
setNextDate($date, $increment_nb_gen_done=0)
Update the next date of execution.
setMaxPeriod($nb)
Update the maximum period.
createRecurringInvoices($restrictioninvoiceid=0, $forcevalidation=0)
Create all recurrents supplier invoices (for all entities if multicompany is used).
update(User $user, $notrigger=0)
Update fourn_invoice_rec.
addline($fk_product, $ref, $label, $desc, $pu_ht, $pu_ttc, $qty, $remise_percent, $txtva, $txlocaltax1=0, $txlocaltax2=0, $price_base_type='HT', $type=0, $date_start=0, $date_end=0, $info_bits=0, $special_code=0, $rang=-1, $fk_unit=null, $pu_ht_devise=0)
Add a line to recursive supplier invoice.
getNomUrl($withpicto=0, $option='', $max=0, $short=0, $moretitle='', $notooltip=0, $save_lastsearch_value=-1)
Return clickable name (with picto eventually)
Class to manage invoice lines.
Class to manage products or services.
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_time_plus_duree($time, $duration_value, $duration_unit, $ruleforendofmonth=0)
Add a delay to a date.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed information (by default a local PHP server timestamp) Rep...
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0)
Show a picto called object_picto (generic function)
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
dol_now($mode='auto')
Return date for now.
getLocalTaxesFromRate($vatrate, $local, $buyer, $seller, $firstparamisid=0)
Get type and rate of localtaxes for a particular vat rate/country of a thirdparty.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
dol_getdate($timestamp, $fast=false, $forcetimezone='')
Return an array with locale date info.
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0, $cleanalsojavascript=0)
Returns text escaped for inclusion in HTML alt or title or value tags, or into values of HTML input f...
calcul_price_total($qty, $pu, $remise_percent_ligne, $txtva, $uselocaltax1_rate, $uselocaltax2_rate, $remise_percent_global, $price_base_type, $info_bits, $type, $seller='', $localtaxes_array=[], $progress=100, $multicurrency_tx=1, $pu_devise=0, $multicurrency_code='')
Calculate totals (net, vat, ...) of a line.
if(preg_match('/crypted:/i', $dolibarr_main_db_pass)||!empty($dolibarr_main_db_encrypted_pass)) $conf db type