221 public function write_file(
$object, $outputlangs, $srctemplatepath =
'', $hidedetails = 0, $hidedesc = 0, $hideref = 0)
224 global $user, $langs, $conf,
$mysoc, $db, $hookmanager;
226 if (!is_object($outputlangs)) {
227 $outputlangs = $langs;
231 $outputlangs->charset_output =
'ISO-8859-1';
235 $outputlangs->loadLangs(array(
"main",
"trips",
"projects",
"dict",
"bills",
"banks"));
237 $nblines = count(
$object->lines);
239 if ($conf->expensereport->dir_output) {
242 $dir = $conf->expensereport->dir_output;
243 $file = $dir.
"/SPECIMEN.pdf";
246 $dir = $conf->expensereport->dir_output.
"/".$objectref;
247 $file = $dir.
"/".$objectref.
".pdf";
250 if (!file_exists($dir)) {
252 $this->error = $langs->transnoentities(
"ErrorCanNotCreateDir", $dir);
257 if (file_exists($dir)) {
259 if (!is_object($hookmanager)) {
260 include_once DOL_DOCUMENT_ROOT.
'/core/class/hookmanager.class.php';
263 $hookmanager->initHooks(array(
'pdfgeneration'));
264 $parameters = array(
'file' => $file,
'object' =>
$object,
'outputlangs' => $outputlangs);
266 $reshook = $hookmanager->executeHooks(
'beforePDFCreation', $parameters,
$object, $action);
271 $heightforinfotot = 40;
273 $heightforfooter = $this->marge_basse + 12;
275 $heightforfooter += 6;
278 $pdf->setAutoPageBreak(
true, 0);
280 if (class_exists(
'TCPDF')) {
281 $pdf->setPrintHeader(
false);
282 $pdf->setPrintFooter(
false);
287 $pagecount = $pdf->setSourceFile($conf->mycompany->dir_output.
'/' .
getDolGlobalString(
'MAIN_ADD_PDF_BACKGROUND'));
288 $tplidx = $pdf->importPage(1);
293 $pdf->SetDrawColor(128, 128, 128);
295 $pdf->SetTitle($outputlangs->convToOutputCharset(
$object->ref));
296 $pdf->SetSubject($outputlangs->transnoentities(
"Trips"));
297 $pdf->SetCreator(
"Dolibarr ".DOL_VERSION);
298 $pdf->SetAuthor($outputlangs->convToOutputCharset($user->getFullName($outputlangs)));
299 $pdf->SetKeyWords($outputlangs->convToOutputCharset(
$object->ref).
" ".$outputlangs->transnoentities(
"Trips"));
301 $pdf->SetCompression(
false);
305 $pdf->SetMargins($this->marge_gauche, $this->marge_haute, $this->marge_droite);
309 if (!empty($tplidx)) {
310 $pdf->useTemplate($tplidx);
314 $pdf->SetFont(
'',
'', $default_font_size - 1);
315 $pdf->MultiCell(0, 3,
'');
316 $pdf->SetTextColor(0, 0, 0);
319 $tab_top_newpage = (!
getDolGlobalInt(
'MAIN_PDF_DONOTREPEAT_HEAD') ? 65 : 10);
321 $tab_height = $this->page_hauteur - $tab_top - $heightforfooter - $heightforfreetext;
324 $notetoshow = empty(
$object->note_public) ?
'' :
$object->note_public;
327 if (is_object(
$object->thirdparty)) {
328 $salereparray =
$object->thirdparty->getSalesRepresentatives($user);
329 $salerepobj =
new User($this->db);
330 $salerepobj->fetch($salereparray[0][
'id']);
331 if (!empty($salerepobj->signature)) {
332 $notetoshow =
dol_concatdesc($notetoshow, $salerepobj->signature);
344 $pdf->SetFont(
'',
'', $default_font_size - 1);
345 $pdf->writeHTMLCell(190, 3, $this->posxpiece - 1, $tab_top,
dol_htmlentitiesbr($notetoshow), 0, 1);
346 $nexY = $pdf->GetY();
347 $height_note = $nexY - $tab_top;
350 $pdf->SetDrawColor(192, 192, 192);
351 $pdf->RoundedRect($this->marge_gauche, $tab_top - 1, $this->page_largeur - $this->marge_gauche - $this->marge_droite, $height_note + 1, $this->corner_radius,
'1234',
'D');
353 $tab_height -= $height_note;
354 $tab_top = $nexY + 6;
359 $iniY = $tab_top + 7;
360 $nexY = $tab_top + 7;
362 $showpricebeforepagebreak = 1;
363 $pdf->setTopMargin($tab_top_newpage);
366 while ($i < $nblines) {
367 $pdf->SetFont(
'',
'', $default_font_size - 2);
368 $pdf->SetTextColor(0, 0, 0);
370 $pdf->setTopMargin($tab_top_newpage);
371 if (empty($showpricebeforepagebreak) && ($i !== ($nblines - 1))) {
372 $pdf->setPageOrientation(
'',
true, $heightforfooter);
374 $pdf->setPageOrientation(
'',
true, $heightforfooter + $heightforfreetext + $heightforinfotot);
377 $pageposbefore = $pdf->getPage();
379 $pdf->startTransaction();
380 $this->
printLine($pdf,
$object, $i, $curY, $default_font_size, $outputlangs, $hidedetails);
381 $pageposafter = $pdf->getPage();
382 if ($pageposafter > $pageposbefore) {
384 $pdf->rollbackTransaction(
true);
386 $pageposafter = $pageposbefore;
388 if (empty($showpricebeforepagebreak)) {
389 $pdf->AddPage(
'',
'',
true);
390 if (!empty($tplidx)) {
391 $pdf->useTemplate($tplidx);
396 $pdf->setPage($pageposafter + 1);
397 $showpricebeforepagebreak = 1;
398 $nexY = $tab_top_newpage;
399 $nexY += ($pdf->getFontSize() * 1.3);
400 $pdf->SetFont(
'',
'', $default_font_size - 2);
401 $pdf->SetTextColor(0, 0, 0);
403 $pdf->setTopMargin($tab_top_newpage);
406 $pdf->setPageOrientation(
'',
true, $heightforfooter);
407 $showpricebeforepagebreak = 0;
410 $this->
printLine($pdf,
$object, $i, $curY, $default_font_size, $outputlangs, $hidedetails);
411 $pageposafter = $pdf->getPage();
412 $posyafter = $pdf->GetY();
414 if ($posyafter > ($this->page_hauteur - ($heightforfooter + $heightforfreetext + $heightforinfotot))) {
416 if ($i == ($nblines - 1)) {
418 $pdf->AddPage(
'',
'',
true);
419 if (!empty($tplidx)) {
420 $pdf->useTemplate($tplidx);
425 $pdf->setPage($pageposafter + 1);
431 $showpricebeforepagebreak = 1;
433 $showpricebeforepagebreak = 0;
437 $pdf->commitTransaction();
441 $nexY = $pdf->GetY();
442 $pageposafter = $pdf->getPage();
443 $pdf->setPage($pageposbefore);
444 $pdf->setTopMargin($this->marge_haute);
445 $pdf->setPageOrientation(
'',
true, 0);
448 $nexY += ($pdf->getFontSize() * 1.3);
451 while ($pagenb < $pageposafter) {
452 $pdf->setPage($pagenb);
453 $pdf->setPageOrientation(
'',
true, 0);
455 $this->
_tableau($pdf, $tab_top, $this->page_hauteur - $tab_top - $heightforfooter, 0, $outputlangs, 0, 1);
457 $this->
_tableau($pdf, $tab_top_newpage, $this->page_hauteur - $tab_top_newpage - $heightforfooter, 0, $outputlangs, 1, 1);
461 $pdf->setPage($pagenb);
462 $pdf->setPageOrientation(
'',
true, 0);
466 if (!empty($tplidx)) {
467 $pdf->useTemplate($tplidx);
470 if (isset(
$object->lines[$i + 1]->pagebreak) &&
$object->lines[$i + 1]->pagebreak) {
472 $this->
_tableau($pdf, $tab_top, $this->page_hauteur - $tab_top - $heightforfooter, 0, $outputlangs, 0, 1);
474 $this->
_tableau($pdf, $tab_top_newpage, $this->page_hauteur - $tab_top_newpage - $heightforfooter, 0, $outputlangs, 1, 1);
479 if (!empty($tplidx)) {
480 $pdf->useTemplate($tplidx);
491 $this->
_tableau($pdf, $tab_top, $this->page_hauteur - $tab_top - $heightforinfotot - $heightforfreetext - $heightforfooter, 0, $outputlangs, 0, 0);
492 $bottomlasttab = $this->page_hauteur - $heightforinfotot - $heightforfreetext - $heightforfooter + 1;
494 $this->
_tableau($pdf, $tab_top_newpage, $this->page_hauteur - $tab_top_newpage - $heightforinfotot - $heightforfreetext - $heightforfooter, 0, $outputlangs, 1, 0);
495 $bottomlasttab = $this->page_hauteur - $heightforinfotot - $heightforfreetext - $heightforfooter + 1;
498 $pdf->SetFont(
'',
'', 10);
501 $posy = $bottomlasttab + 5;
502 $posy_start_of_totals = $posy;
503 $pdf->SetXY(120, $posy);
504 $pdf->MultiCell(40, 5, $outputlangs->transnoentities(
"TotalHT"), 1,
'L');
505 $pdf->SetXY(160, $posy);
506 $pdf->MultiCell($this->page_largeur - $this->marge_gauche - 160, 5,
price(
$object->total_ht), 1,
'C');
507 $pdf->SetFillColor(248, 248, 248);
512 $pdf->SetXY(120, $posy);
513 $pdf->SetTextColor(0, 0, 60);
514 $pdf->MultiCell(40, 5, $outputlangs->transnoentities(
"TotalVAT"), 1,
'L');
515 $pdf->SetXY(160, $posy);
516 $pdf->MultiCell($this->page_largeur - $this->marge_gauche - 160, 5,
price(
$object->total_tva), 1,
'C');
520 $pdf->SetXY(120, $posy);
521 $pdf->SetFont(
'',
'B', 10);
522 $pdf->SetTextColor(0, 0, 60);
523 $pdf->MultiCell(40, 5, $outputlangs->transnoentities(
"TotalTTC"), 1,
'L');
524 $pdf->SetXY(160, $posy);
525 $pdf->MultiCell($this->page_largeur - $this->marge_gauche - 160, 5,
price(
$object->total_ttc), 1,
'C');
528 $sumPayments =
$object->getSumPayments();
529 if ($sumPayments > 0 && !
getDolGlobalString(
'PDF_EXPENSEREPORT_NO_PAYMENT_DETAILS')) {
535 if (method_exists($pdf,
'AliasNbPages')) {
536 $pdf->AliasNbPages();
541 $pdf->Output($file,
'F');
544 $hookmanager->initHooks(array(
'pdfgeneration'));
545 $parameters = array(
'file' => $file,
'object' =>
$object,
'outputlangs' => $outputlangs);
547 $reshook = $hookmanager->executeHooks(
'afterPDFCreation', $parameters, $this, $action);
548 $this->warnings = $hookmanager->warnings;
550 $this->error = $hookmanager->error;
551 $this->errors = $hookmanager->errors;
558 $this->result = array(
'fullpath' => $file);
562 $this->error = $langs->trans(
"ErrorCanNotCreateDir", $dir);
566 $this->error = $langs->trans(
"ErrorConstantNotDefined",
"EXPENSEREPORT_OUTPUTDIR");
581 protected function printLine(&$pdf,
$object, $linenumber, $curY, $default_font_size, $outputlangs, $hidedetails = 0)
584 $pdf->SetFont(
'',
'', $default_font_size - 1);
585 $pdf->SetTextColor(0, 0, 0);
588 $pdf->SetXY($this->posxpiece, $curY);
589 $pdf->writeHTMLCell($this->posxcomment - $this->posxpiece - 0.8, 4, $this->posxpiece - 1, $curY, (
string) ($linenumber + 1), 0, 1);
596 $pdf->SetXY($this->posxtype - 1, $curY);
597 $nextColumnPosX = $this->posxup;
599 $nextColumnPosX = $this->posxtva;
602 $nextColumnPosX = $this->posxprojet;
605 $expensereporttypecode =
$object->lines[$linenumber]->type_fees_code;
606 $expensereporttypecodetoshow = ($outputlangs->trans(($expensereporttypecode)) == $expensereporttypecode ?
$object->lines[$linenumber]->type_fees_libelle : $outputlangs->trans($expensereporttypecode));
609 if ($expensereporttypecodetoshow == $expensereporttypecode) {
610 $expensereporttypecodetoshow = preg_replace(
'/^(EX_|TF_)/',
'', $expensereporttypecodetoshow);
627 $pdf->SetXY($this->posxtva, $curY);
628 $pdf->MultiCell($this->posxup - $this->posxtva - 0.8, 4, $vat_rate, 0,
'C');
632 $pdf->SetXY($this->posxup, $curY);
633 $pdf->MultiCell($this->posxqty - $this->posxup - 0.8, 4,
price(
$object->lines[$linenumber]->value_unit), 0,
'C');
636 $pdf->SetXY($this->posxqty, $curY);
637 $pdf->MultiCell($this->postotalht - $this->posxqty - 0.8, 4, (
string)
$object->lines[$linenumber]->qty, 0,
'C');
640 $pdf->SetXY($this->postotalht, $curY);
641 $pdf->MultiCell($this->postotalttc - $this->postotalht - 0.8, 4,
price(
$object->lines[$linenumber]->total_ht), 0,
'C');
644 $pdf->SetXY($this->postotalttc - 1, $curY);
645 $pdf->MultiCell($this->page_largeur - $this->marge_droite - $this->postotalttc + 1, 4,
price(
$object->lines[$linenumber]->total_ttc), 0,
'C');
648 $pdf->SetXY($this->posxcomment, $curY);
649 $comment = $outputlangs->trans(
"Date").
':'.
dol_print_date(
$object->lines[$linenumber]->date,
"day",
false, $outputlangs).
' ';
650 $comment .= $outputlangs->trans(
"Type").
':'.$expensereporttypecodetoshow.
'<br>';
651 if (!empty(
$object->lines[$linenumber]->projet_ref)) {
652 $comment .= $outputlangs->trans(
"Project").
':'.
$object->lines[$linenumber]->projet_ref.
'<br>';
654 $comment .=
$object->lines[$linenumber]->comments;
655 $pdf->writeHTMLCell($this->posxtva - $this->posxcomment - 0.8, 4, $this->posxcomment - 1, $curY, $comment, 0, 1);
671 global $user, $langs, $conf,
$mysoc, $db, $hookmanager;
674 $outputlangs->loadLangs(array(
"main",
"trips",
"companies"));
688 pdf_watermark($pdf, $outputlangs, $this->page_hauteur, $this->page_largeur,
'mm', $conf->global->EXPENSEREPORT_DRAFT_WATERMARK);
691 $pdf->SetTextColor(0, 0, 60);
692 $pdf->SetFont(
'',
'B', $default_font_size + 3);
694 $posy = $this->marge_haute;
695 $posx = $this->page_largeur - $this->marge_droite - 100;
697 $pdf->SetXY($this->marge_gauche, $posy);
700 $logo = $conf->mycompany->dir_output.
'/logos/'.$this->emetteur->logo;
701 if ($this->emetteur->logo) {
702 if (is_readable($logo)) {
704 $pdf->Image($logo, $this->marge_gauche, $posy, 0, $height);
706 $pdf->SetTextColor(200, 0, 0);
707 $pdf->SetFont(
'',
'B', $default_font_size - 2);
708 $pdf->MultiCell(100, 3, $outputlangs->transnoentities(
"ErrorLogoFileNotFound", $logo), 0,
'L');
709 $pdf->MultiCell(100, 3, $outputlangs->transnoentities(
"ErrorGoToGlobalSetup"), 0,
'L');
712 $text = $this->emetteur->name;
713 $pdf->MultiCell(100, 4, $outputlangs->convToOutputCharset($text), 0,
'L');
716 $pdf->SetFont(
'',
'B', $default_font_size + 4);
717 $pdf->SetXY($posx, $posy);
718 $pdf->SetTextColor(0, 0, 60);
719 $pdf->MultiCell($this->page_largeur - $this->marge_droite - $posx, 6, $outputlangs->trans(
"ExpenseReport"), 0,
'R');
721 $pdf->SetFont(
'',
'', $default_font_size - 1);
725 $pdf->SetXY($posx, $posy);
726 $pdf->SetTextColor(0, 0, 60);
727 $pdf->MultiCell($this->page_largeur - $this->marge_droite - $posx, 3, $outputlangs->transnoentities(
"Ref").
" : ".
$object->ref,
'',
'R');
731 $pdf->SetXY($posx, $posy);
732 $pdf->SetTextColor(0, 0, 60);
733 $pdf->MultiCell($this->page_largeur - $this->marge_droite - $posx, 3, $outputlangs->transnoentities(
"DateStart").
" : ".(
$object->date_debut > 0 ?
dol_print_date(
$object->date_debut,
"day",
false, $outputlangs) :
''),
'',
'R');
737 $pdf->SetXY($posx, $posy);
738 $pdf->SetTextColor(0, 0, 60);
739 $pdf->MultiCell($this->page_largeur - $this->marge_droite - $posx, 3, $outputlangs->transnoentities(
"DateEnd").
" : ".(
$object->date_fin > 0 ?
dol_print_date(
$object->date_fin,
"day",
false, $outputlangs) :
''),
'',
'R');
743 $pdf->SetXY($posx, $posy);
744 $pdf->SetFont(
'',
'B', $default_font_size + 2);
745 $pdf->SetTextColor(111, 81, 124);
746 $pdf->MultiCell($this->page_largeur - $this->marge_droite - $posx, 3, $outputlangs->transnoentities(
$object->labelStatusShort[
$object->status]),
'',
'R');
750 $carac_emetteur =
'';
751 $carac_emetteur .= ($carac_emetteur ?
"\n" :
'').$outputlangs->convToOutputCharset($this->emetteur->address);
752 $carac_emetteur .= ($carac_emetteur ?
"\n" :
'').$outputlangs->convToOutputCharset($this->emetteur->zip).
' '.$outputlangs->convToOutputCharset($this->emetteur->town);
753 $carac_emetteur .=
"\n";
754 if ($this->emetteur->phone) {
755 $carac_emetteur .= ($carac_emetteur ?
"\n" :
'').$outputlangs->transnoentities(
"Phone").
" : ".$outputlangs->convToOutputCharset($this->emetteur->phone);
757 if ($this->emetteur->fax) {
758 $carac_emetteur .= ($carac_emetteur ? ($this->emetteur->tel ?
" - " :
"\n") :
'').$outputlangs->transnoentities(
"Fax").
" : ".$outputlangs->convToOutputCharset($this->emetteur->fax);
760 if ($this->emetteur->email) {
761 $carac_emetteur .= ($carac_emetteur ?
"\n" :
'').$outputlangs->transnoentities(
"Email").
" : ".$outputlangs->convToOutputCharset($this->emetteur->email);
763 if ($this->emetteur->url) {
764 $carac_emetteur .= ($carac_emetteur ?
"\n" :
'').$outputlangs->transnoentities(
"Web").
" : ".$outputlangs->convToOutputCharset($this->emetteur->url);
768 $receiver =
new User($this->db);
769 $receiver->fetch(
$object->fk_user_author);
771 $receiver_account->fetch(0,
'',
$object->fk_user_author);
772 $expense_receiver =
'';
773 $expense_receiver .= ($expense_receiver ?
"\n" :
'').$outputlangs->convToOutputCharset($receiver->address);
774 $expense_receiver .= ($expense_receiver ?
"\n" :
'').$outputlangs->convToOutputCharset($receiver->zip).
' '.$outputlangs->convToOutputCharset($receiver->town);
775 $expense_receiver .=
"\n";
776 if ($receiver->email) {
777 $expense_receiver .= ($expense_receiver ?
"\n" :
'').$outputlangs->transnoentities(
"Email").
" : ".$outputlangs->convToOutputCharset($receiver->email);
779 if ($receiver_account->iban) {
780 $expense_receiver .= ($expense_receiver ?
"\n" :
'').$outputlangs->transnoentities(
"IBAN").
" : ".$outputlangs->convToOutputCharset($receiver_account->iban);
785 $posx = $this->marge_gauche;
792 $pdf->SetTextColor(0, 0, 0);
793 $pdf->SetFont(
'',
'B', $default_font_size - 2);
794 $pdf->SetXY($posx, $posy - 5);
795 $pdf->MultiCell(80, 5, $outputlangs->transnoentities(
"TripSociete"),
'',
'L');
796 $pdf->SetXY($posx, $posy);
797 $pdf->SetFillColor(224, 224, 224);
798 $pdf->RoundedRect($posx, $posy, 82, $hautcadre, $this->corner_radius,
'1234',
'F');
799 $pdf->SetTextColor(0, 0, 60);
803 $pdf->SetXY($posx + 2, $posy + 3);
804 $pdf->SetFont(
'',
'B', $default_font_size);
805 $pdf->MultiCell(80, 4, $outputlangs->convToOutputCharset($this->emetteur->name), 0,
'L');
806 $pdf->SetXY($posx + 2, $posy + 8);
807 $pdf->SetFont(
'',
'', $default_font_size - 1);
808 $pdf->MultiCell(80, 4, $carac_emetteur, 0,
'L');
810 $pdf->SetXY($posx + 2, $posy + 3);
811 $pdf->SetFont(
'',
'B', $default_font_size);
812 $pdf->MultiCell(80, 4, $outputlangs->convToOutputCharset(
dolGetFirstLastname($receiver->firstname, $receiver->lastname)), 0,
'L');
813 $pdf->SetXY($posx + 2, $posy + 8);
814 $pdf->SetFont(
'',
'', $default_font_size - 1);
815 $pdf->MultiCell(80, 4, $expense_receiver, 0,
'L');
822 $posx = $this->marge_gauche;
826 $pdf->SetTextColor(0, 0, 0);
827 $pdf->SetFont(
'',
'B', 8);
828 $pdf->SetXY($posx, $posy - 5);
829 $pdf->MultiCell(80, 5, $outputlangs->transnoentities(
"TripNDF").
" :", 0,
'L');
830 $pdf->RoundedRect($posx, $posy, $this->page_largeur - $this->marge_gauche - $posx, $hautcadre, $this->corner_radius,
'1234',
'D');
833 if (
$object->fk_user_author > 0) {
834 $userfee =
new User($this->db);
835 $userfee->fetch(
$object->fk_user_author);
837 $pdf->SetXY($posx + 2, $posy);
838 $pdf->SetFont(
'',
'', 10);
839 $pdf->MultiCell(96, 4, $outputlangs->transnoentities(
"AUTHOR").
" : ".
dolGetFirstLastname($userfee->firstname, $userfee->lastname), 0,
'L');
840 $posy = $pdf->GetY() + 1;
841 $pdf->SetXY($posx + 2, $posy);
842 $pdf->MultiCell(96, 4, $outputlangs->transnoentities(
"DateCreation").
" : ".
dol_print_date(
$object->date_create,
"day",
false, $outputlangs), 0,
'L');
845 if (
$object->fk_statut == 99) {
846 if (
$object->fk_user_refuse > 0) {
847 $userfee =
new User($this->db);
848 $userfee->fetch(
$object->fk_user_refuse);
850 $pdf->SetXY($posx + 2, $posy);
851 $pdf->MultiCell(96, 4, $outputlangs->transnoentities(
"REFUSEUR").
" : ".
dolGetFirstLastname($userfee->firstname, $userfee->lastname), 0,
'L');
853 $pdf->SetXY($posx + 2, $posy);
854 $pdf->MultiCell(96, 4, $outputlangs->transnoentities(
"MOTIF_REFUS").
" : ".$outputlangs->convToOutputCharset(
$object->detail_refuse), 0,
'L');
856 $pdf->SetXY($posx + 2, $posy);
857 $pdf->MultiCell(96, 4, $outputlangs->transnoentities(
"DATE_REFUS").
" : ".
dol_print_date(
$object->date_refuse,
"day",
false, $outputlangs), 0,
'L');
859 } elseif (
$object->fk_statut == 4) {
860 if (
$object->fk_user_cancel > 0) {
861 $userfee =
new User($this->db);
862 $userfee->fetch(
$object->fk_user_cancel);
864 $pdf->SetXY($posx + 2, $posy);
865 $pdf->MultiCell(96, 4, $outputlangs->transnoentities(
"CANCEL_USER").
" : ".
dolGetFirstLastname($userfee->firstname, $userfee->lastname), 0,
'L');
867 $pdf->SetXY($posx + 2, $posy);
868 $pdf->MultiCell(96, 4, $outputlangs->transnoentities(
"MOTIF_CANCEL").
" : ".$outputlangs->convToOutputCharset(
$object->detail_cancel), 0,
'L');
870 $pdf->SetXY($posx + 2, $posy);
871 $pdf->MultiCell(96, 4, $outputlangs->transnoentities(
"DATE_CANCEL").
" : ".
dol_print_date(
$object->date_cancel,
"day",
false, $outputlangs), 0,
'L');
874 if (
$object->fk_user_approve > 0) {
875 $userfee =
new User($this->db);
876 $userfee->fetch(
$object->fk_user_approve);
878 $pdf->SetXY($posx + 2, $posy);
879 $pdf->MultiCell(96, 4, $outputlangs->transnoentities(
"VALIDOR").
" : ".
dolGetFirstLastname($userfee->firstname, $userfee->lastname), 0,
'L');
881 $pdf->SetXY($posx + 2, $posy);
882 $pdf->MultiCell(96, 4, $outputlangs->transnoentities(
"DateApprove").
" : ".
dol_print_date(
$object->date_approve,
"day",
false, $outputlangs), 0,
'L');
887 if (
$object->fk_user_paid > 0) {
888 $userfee =
new User($this->db);
889 $userfee->fetch(
$object->fk_user_paid);
891 $pdf->SetXY($posx + 2, $posy);
892 $pdf->MultiCell(96, 4, $outputlangs->transnoentities(
"AUTHORPAIEMENT").
" : ".
dolGetFirstLastname($userfee->firstname, $userfee->lastname), 0,
'L');
894 $pdf->SetXY($posx + 2, $posy);
895 $pdf->MultiCell(96, 4, $outputlangs->transnoentities(
"DATE_PAIEMENT").
" : ".
dol_print_date(
$object->date_paiement,
"day",
false, $outputlangs), 0,
'L');
917 protected function _tableau(&$pdf, $tab_top, $tab_height, $nexY, $outputlangs, $hidetop = 0, $hidebottom = 0, $currency =
'')
927 $currency = !empty($currency) ? $currency : $conf->currency;
931 $pdf->SetTextColor(0, 0, 0);
932 $pdf->SetFont(
'',
'', $default_font_size - 2);
933 $titre = $outputlangs->transnoentities(
"AmountInCurrency", $outputlangs->transnoentitiesnoconv(
"Currency".$currency));
934 $pdf->SetXY($this->page_largeur - $this->marge_droite - ($pdf->GetStringWidth($titre) + 4), $tab_top - 4);
935 $pdf->MultiCell(($pdf->GetStringWidth($titre) + 3), 2, $titre);
937 $pdf->SetDrawColor(128, 128, 128);
940 $pdf->RoundedRect($this->marge_gauche, $tab_top, $this->page_largeur - $this->marge_gauche - $this->marge_droite, $tab_height, $this->corner_radius,
'1234',
'D');
941 if (empty($hidetop)) {
942 $pdf->line($this->marge_gauche, $tab_top + 5, $this->page_largeur - $this->marge_droite, $tab_top + 5);
945 $pdf->SetFont(
'',
'', 8);
948 if (empty($hidetop)) {
949 $pdf->SetXY($this->posxpiece - 1, $tab_top + 1);
950 $pdf->MultiCell($this->posxcomment - $this->posxpiece - 0.8, 1,
'',
'',
'R');
954 $pdf->line($this->posxcomment - 1, $tab_top, $this->posxcomment - 1, $tab_top + $tab_height);
955 if (empty($hidetop)) {
956 $pdf->SetXY($this->posxcomment - 1, $tab_top + 1);
957 $pdf->MultiCell($this->posxdate - $this->posxcomment - 0.8, 1, $outputlangs->transnoentities(
"Description"),
'',
'L');
988 $pdf->line($this->posxtva - 1, $tab_top, $this->posxtva - 1, $tab_top + $tab_height);
989 if (empty($hidetop)) {
990 $pdf->SetXY($this->posxtva - 0.8, $tab_top + 1);
991 $pdf->MultiCell($this->posxup - $this->posxtva - 1, 2, $outputlangs->transnoentities(
"VAT"),
'',
'C');
996 $pdf->line($this->posxup - 1, $tab_top, $this->posxup - 1, $tab_top + $tab_height);
997 if (empty($hidetop)) {
998 $pdf->SetXY($this->posxup - 0.8, $tab_top + 1);
999 $pdf->MultiCell($this->posxqty - $this->posxup - 1, 2, $outputlangs->transnoentities(
"PriceUTTC"),
'',
'C');
1003 $pdf->line($this->posxqty - 1, $tab_top, $this->posxqty - 1, $tab_top + $tab_height);
1004 if (empty($hidetop)) {
1005 $pdf->SetXY($this->posxqty - 0.8, $tab_top + 1);
1006 $pdf->MultiCell($this->postotalht - $this->posxqty - 1, 2, $outputlangs->transnoentities(
"Qty"),
'',
'C');
1010 $pdf->line($this->postotalht - 1, $tab_top, $this->postotalht - 1, $tab_top + $tab_height);
1011 if (empty($hidetop)) {
1012 $pdf->SetXY($this->postotalht - 0.8, $tab_top + 1);
1013 $pdf->MultiCell($this->postotalttc - $this->postotalht + 1, 2, $outputlangs->transnoentities(
"TotalHT"),
'',
'C');
1017 $pdf->line($this->postotalttc, $tab_top, $this->postotalttc, $tab_top + $tab_height);
1018 if (empty($hidetop)) {
1019 $pdf->SetXY($this->postotalttc - 0.8, $tab_top + 1);
1020 $pdf->MultiCell($this->page_largeur - $this->marge_droite - $this->postotalttc + 1, 2, $outputlangs->transnoentities(
"TotalTTC"),
'',
'R');
1023 $pdf->SetTextColor(0, 0, 0);
1040 $tab3_posx = $this->marge_gauche;
1047 $title = $outputlangs->transnoentities(
"PaymentsAlreadyDone");
1048 $pdf->SetFont(
'',
'', $default_font_size - 2);
1049 $pdf->SetXY($tab3_posx, $tab3_top - 4);
1050 $pdf->SetTextColor(0, 0, 0);
1051 $pdf->MultiCell(60, 3, $title, 0,
'L',
false);
1053 $pdf->line($tab3_posx, $tab3_top, $tab3_posx + $tab3_width + 2, $tab3_top);
1055 $pdf->SetXY($tab3_posx, $tab3_top + 1);
1056 $pdf->MultiCell(20, 3, $outputlangs->transnoentities(
"Date"), 0,
'L',
false);
1057 $pdf->SetXY($tab3_posx + 19, $tab3_top + 1);
1058 $pdf->MultiCell(15, 3, $outputlangs->transnoentities(
"Amount"), 0,
'C',
false);
1059 $pdf->SetXY($tab3_posx + 45, $tab3_top + 1);
1060 $pdf->MultiCell(35, 3, $outputlangs->transnoentities(
"Type"), 0,
'L',
false);
1062 $pdf->SetXY($tab3_posx + 65, $tab3_top + 1);
1063 $pdf->MultiCell(25, 3, $outputlangs->transnoentities(
"BankAccount"), 0,
'L',
false);
1065 $pdf->line($tab3_posx, $tab3_top + $tab3_height, $tab3_posx + $tab3_width + 2, $tab3_top + $tab3_height);
1072 $sql =
"SELECT p.rowid, p.num_payment, p.datep as dp, p.amount, p.fk_bank,";
1073 $sql .=
"c.code as p_code, c.libelle as payment_type,";
1074 $sql .=
"ba.rowid as baid, ba.ref as baref, ba.label, ba.number as banumber, ba.account_number, ba.fk_accountancy_journal";
1075 $sql .=
" FROM ".MAIN_DB_PREFIX.
"expensereport as e, ".MAIN_DB_PREFIX.
"payment_expensereport as p";
1076 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_paiement as c ON p.fk_typepayment = c.id";
1077 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'bank as b ON p.fk_bank = b.rowid';
1078 $sql .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'bank_account as ba ON b.fk_account = ba.rowid';
1079 $sql .=
" WHERE e.rowid = ".((int)
$object->id);
1080 $sql .=
" AND p.fk_expensereport = e.rowid";
1081 $sql .=
' AND e.entity IN ('.getEntity(
'expensereport').
')';
1082 $sql .=
" ORDER BY dp";
1084 $resql = $this->db->query($sql);
1086 $num = $this->db->num_rows($resql);
1091 $row = $this->db->fetch_object($resql);
1093 $pdf->SetXY($tab3_posx, $tab3_top + $y + 1);
1094 $pdf->MultiCell(20, 3,
dol_print_date($this->db->jdate($row->dp),
'day',
false, $outputlangs,
true), 0,
'L',
false);
1095 $pdf->SetXY($tab3_posx + 20, $tab3_top + $y + 1);
1096 $pdf->MultiCell(20, 3,
price($sign * $row->amount, 0, $outputlangs), 0,
'L',
false);
1097 $pdf->SetXY($tab3_posx + 45, $tab3_top + $y + 1);
1098 $oper = $outputlangs->transnoentitiesnoconv(
"PaymentTypeShort".$row->p_code);
1100 $pdf->MultiCell(40, 3, $oper, 0,
'L',
false);
1102 $pdf->SetXY($tab3_posx + 65, $tab3_top + $y + 1);
1103 $pdf->MultiCell(30, 3, $row->baref, 0,
'L',
false);
1106 $pdf->line($tab3_posx, $tab3_top + $y + $tab3_height, $tab3_posx + $tab3_width + 2, $tab3_top + $y + $tab3_height);
1107 $totalpaid += $row->amount;
1110 if ($num > 0 &&
$object->paid == 0) {
1113 $pdf->SetXY($tab3_posx + 17, $tab3_top + $y);
1114 $pdf->MultiCell(20, 3,
price($totalpaid), 0,
'R',
false);
1115 $pdf->SetXY($tab3_posx + 40, $tab3_top + $y);
1116 $pdf->MultiCell(30, 4, $outputlangs->transnoentitiesnoconv(
"AlreadyPaid"), 0,
'L',
false);
1117 $y += $tab3_height - 2;
1118 $pdf->SetXY($tab3_posx + 17, $tab3_top + $y);
1119 $pdf->MultiCell(20, 3,
price(
$object->total_ttc), 0,
'R',
false);
1120 $pdf->SetXY($tab3_posx + 40, $tab3_top + $y);
1121 $pdf->MultiCell(30, 4, $outputlangs->transnoentitiesnoconv(
"AmountExpected"), 0,
'L',
false);
1122 $y += $tab3_height - 2;
1123 $remaintopay =
$object->total_ttc - $totalpaid;
1124 $pdf->SetXY($tab3_posx + 17, $tab3_top + $y);
1125 $pdf->MultiCell(20, 3,
price($remaintopay), 0,
'R',
false);
1126 $pdf->SetXY($tab3_posx + 40, $tab3_top + $y);
1127 $pdf->MultiCell(30, 4, $outputlangs->transnoentitiesnoconv(
"RemainderToPay"), 0,
'L',
false);
1130 $this->error = $this->db->lasterror();