38require
'../main.inc.php';
48require_once DOL_DOCUMENT_ROOT.
'/projet/class/project.class.php';
49require_once DOL_DOCUMENT_ROOT.
'/projet/class/task.class.php';
50require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formprojet.class.php';
51require_once DOL_DOCUMENT_ROOT.
'/core/lib/project.lib.php';
52require_once DOL_DOCUMENT_ROOT.
'/core/lib/date.lib.php';
53require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formfile.class.php';
54require_once DOL_DOCUMENT_ROOT.
'/core/class/timespent.class.php';
57 require_once DOL_DOCUMENT_ROOT.
'/comm/action/class/actioncomm.class.php';
60 require_once DOL_DOCUMENT_ROOT.
'/compta/bank/class/paymentvarious.class.php';
63 require_once DOL_DOCUMENT_ROOT.
'/categories/class/categorie.class.php';
66 require_once DOL_DOCUMENT_ROOT.
'/commande/class/commande.class.php';
69 require_once DOL_DOCUMENT_ROOT.
'/contrat/class/contrat.class.php';
72 require_once DOL_DOCUMENT_ROOT.
'/compta/deplacement/class/deplacement.class.php';
75 require_once DOL_DOCUMENT_ROOT.
'/don/class/don.class.php';
78 require_once DOL_DOCUMENT_ROOT.
'/expedition/class/expedition.class.php';
81 require_once DOL_DOCUMENT_ROOT.
'/expensereport/class/expensereport.class.php';
84 require_once DOL_DOCUMENT_ROOT.
'/compta/facture/class/facture.class.php';
85 require_once DOL_DOCUMENT_ROOT.
'/compta/facture/class/facture-rec.class.php';
88 require_once DOL_DOCUMENT_ROOT.
'/fichinter/class/fichinter.class.php';
91 require_once DOL_DOCUMENT_ROOT.
'/loan/class/loan.class.php';
92 require_once DOL_DOCUMENT_ROOT.
'/loan/class/loanschedule.class.php';
95 require_once DOL_DOCUMENT_ROOT.
'/mrp/class/mo.class.php';
98 require_once DOL_DOCUMENT_ROOT.
'/comm/propal/class/propal.class.php';
101 require_once DOL_DOCUMENT_ROOT.
'/salaries/class/salary.class.php';
104 require_once DOL_DOCUMENT_ROOT.
'/product/stock/class/entrepot.class.php';
105 require_once DOL_DOCUMENT_ROOT.
'/product/stock/class/mouvementstock.class.php';
108 require_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.facture.class.php';
111 require_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.commande.class.php';
114 require_once DOL_DOCUMENT_ROOT.
'/supplier_proposal/class/supplier_proposal.class.php';
117 require_once DOL_DOCUMENT_ROOT.
'/compta/sociales/class/chargesociales.class.php';
120 require_once DOL_DOCUMENT_ROOT.
'/product/stock/stocktransfer/class/stocktransfer.class.php';
121 require_once DOL_DOCUMENT_ROOT.
'/product/stock/stocktransfer/class/stocktransferline.class.php';
125$langs->loadLangs(array(
'projects',
'companies',
'suppliers',
'compta'));
127 $langs->load(
"bills");
130 $langs->load(
"orders");
133 $langs->load(
"propal");
136 $langs->load(
"interventions");
139 $langs->load(
"trips");
142 $langs->load(
"trips");
145 $langs->load(
"donations");
148 $langs->load(
"loan");
151 $langs->load(
"salaries");
157 $langs->load(
"eventorganization");
162$action =
GETPOST(
'action',
'aZ09');
163$datesrfc =
GETPOST(
'datesrfc');
164$dateerfc =
GETPOST(
'dateerfc');
167if (empty($dates) && !empty($datesrfc)) {
170if (empty($datee) && !empty($dateerfc)) {
173if (!GETPOSTISSET(
'datesrfc') && !GETPOSTISSET(
'datesday') &&
getDolGlobalString(
'PROJECT_LINKED_ELEMENT_DEFAULT_FILTER_YEAR')) {
180if ($id ==
'' && $ref ==
'') {
182 header(
'Location: list.php');
186$mine =
GETPOST(
'mode') ==
'mine' ? 1 : 0;
190include DOL_DOCUMENT_ROOT.
'/core/actions_fetchobject.inc.php';
191if (
getDolGlobalString(
'PROJECT_ALLOW_COMMENT_ON_PROJECT') && method_exists($object,
'fetchComments') && empty(
$object->comments)) {
198$hookmanager->initHooks(array(
'projectOverview'));
205 (
isModEnabled(
'invoice') && $user->hasRight(
'facture',
'lire'))
206 || (
isModEnabled(
'supplier_invoice') && ($user->hasRight(
'fournisseur',
'facture',
'lire') || $user->hasRight(
'supplier_invoice',
'lire')))
207 || (
isModEnabled(
'salaries') && $user->hasRight(
'salaries',
'read'))
208 || (
isModEnabled(
'expensereport') && $user->hasRight(
'expensereport',
'lire'))
209 || (
isModEnabled(
'don') && $user->hasRight(
'don',
'lire'))
210 || (
isModEnabled(
'tax') && $user->hasRight(
'tax',
'charges',
'lire'))
211 || (
isModEnabled(
'bank') && $user->hasRight(
'banque',
'lire'))
215$total_ttc_by_line = 0;
216$total_ht_by_line = 0;
217$expensereport =
null;
219$tmpprojtime = array();
222$permissiontoadd = $user->hasRight(
'projet',
'creer');
223$permissiontodelete = $user->hasRight(
'projet',
'supprimer');
224$permissiondellink = $user->hasRight(
'projet',
'creer');
225$permissiontoeditextra = $permissiontoadd;
226if (
GETPOST(
'attribute',
'aZ09') && isset($extrafields->attributes[
$object->table_element][
'perms'][
GETPOST(
'attribute',
'aZ09')])) {
228 $permissiontoeditextra =
dol_eval($extrafields->attributes[
$object->table_element][
'perms'][
GETPOST(
'attribute',
'aZ09')]);
236if ($action ==
'update_extras' && $permissiontoeditextra) {
240 $attribute_name =
GETPOST(
'attribute',
'aZ09');
243 $ret = $extrafields->setOptionalsFromPost(
null, $object, $attribute_name);
249 $result =
$object->updateExtraField($attribute_name,
'PROJECT_MODIFY');
257 $action =
'edit_extras';
260if (($action ==
'updateundefinedwithlasthourlyrate' || $action ==
'updateallwithlasthourlyrate') && $permissiontoadd) {
262 if (!GETPOSTISSET(
'taskid')) {
268 $sql =
"SELECT et.rowid as id, u.thm as thmuser";
269 $sql .=
" FROM ".MAIN_DB_PREFIX.
"element_time as et";
270 $sql .=
" INNER JOIN ".MAIN_DB_PREFIX.
"user as u ON u.rowid = et.fk_user";
271 $sql .=
" WHERE et.elementtype = 'task'";
272 $sql .=
" AND et.fk_element = ".((int) $taskid);
273 if ($action ==
'updateundefinedwithlasthourlyrate') {
274 $sql .=
" AND et.thm IS NULL";
277 $resql = $db->query($sql);
279 $num = $db->num_rows($resql);
282 $obj = $db->fetch_object($resql);
283 if (empty($obj->thmuser)) {
288 $res = $timespent->fetch($obj->id);
294 $timespent->thm = $obj->thmuser;
295 $res = $timespent->update($user);
322$title = $langs->trans(
'ProjectReferers').
' - '.
$object->ref.
' '.
$object->name;
324 $title =
$object->ref.
' '.
$object->name.
' - '.$langs->trans(
'ProjectReferers');
327$help_url =
'EN:Module_Projects|FR:Module_Projets|ES:Módulo_Proyectos|DE:Modul_Projekte';
329llxHeader(
'', $title, $help_url,
'', 0, 0,
'',
'',
'',
'mod-project page-card_element');
331$form =
new Form($db);
335$userstatic =
new User($db);
338$userAccess =
$object->restrictedProjectArea($user);
346if (!empty($_SESSION[
'pageforbacktolist']) && !empty($_SESSION[
'pageforbacktolist'][
'project'])) {
347 $tmpurl = $_SESSION[
'pageforbacktolist'][
'project'];
348 $tmpurl = preg_replace(
'/__SOCID__/', (
string)
$object->socid, $tmpurl);
349 $linkback =
'<a href="'.$tmpurl.(preg_match(
'/\?/', $tmpurl) ?
'&' :
'?').
'restore_lastsearch_values=1">'.$langs->trans(
"BackToList").
'</a>';
351 $linkback =
'<a href="'.DOL_URL_ROOT.
'/projet/list.php?restore_lastsearch_values=1">'.$langs->trans(
"BackToList").
'</a>';
354$morehtmlref =
'<div class="refidno">';
358if (!empty(
$object->thirdparty->id) &&
$object->thirdparty->id > 0) {
359 $morehtmlref .=
'<br>'.$object->thirdparty->getNomUrl(1,
'project');
361$morehtmlref .=
'</div>';
364if (!$user->hasRight(
'projet',
'all',
'lire')) {
365 $objectsListId =
$object->getProjectsAuthorizedForUser($user, 0, 0);
366 $object->next_prev_filter =
"te.rowid:IN:".$db->sanitize(count($objectsListId) ? implode(
',', array_keys($objectsListId)) :
'0');
369dol_banner_tab($object,
'ref', $linkback, 1,
'ref',
'ref', $morehtmlref);
372print
'<div class="fichecenter">';
373print
'<div class="fichehalfleft">';
374print
'<div class="underbanner clearboth"></div>';
376print
'<table class="border tableforfield centpercent">';
380 print
'<tr><td class="tdtop">';
381 print $langs->trans(
"Usage");
385 print
'<input type="checkbox" disabled name="usage_opportunity"'.(GETPOSTISSET(
'usage_opportunity') ? (
GETPOST(
'usage_opportunity',
'alpha') !=
'' ?
' checked="checked"' :
'') : (
$object->usage_opportunity ?
' checked="checked"' :
'')).
'"> ';
386 $htmltext = $langs->trans(
"ProjectFollowOpportunity");
387 print $form->textwithpicto($langs->trans(
"ProjectFollowOpportunity"), $htmltext);
391 print
'<input type="checkbox" disabled name="usage_task"'.(GETPOSTISSET(
'usage_task') ? (
GETPOST(
'usage_task',
'alpha') !=
'' ?
' checked="checked"' :
'') : (
$object->usage_task ?
' checked="checked"' :
'')).
'"> ';
392 $htmltext = $langs->trans(
"ProjectFollowTasks");
393 print $form->textwithpicto($langs->trans(
"ProjectFollowTasks"), $htmltext);
397 print
'<input type="checkbox" disabled name="usage_bill_time"'.(GETPOSTISSET(
'usage_bill_time') ? (
GETPOST(
'usage_bill_time',
'alpha') !=
'' ?
' checked="checked"' :
'') : (
$object->usage_bill_time ?
' checked="checked"' :
'')).
'"> ';
398 $htmltext = $langs->trans(
"ProjectBillTimeDescription");
399 print $form->textwithpicto($langs->trans(
"BillTime"), $htmltext);
403 print
'<input type="checkbox" disabled name="usage_organize_event"'.(GETPOSTISSET(
'usage_organize_event') ? (
GETPOST(
'usage_organize_event',
'alpha') !=
'' ?
' checked="checked"' :
'') : (
$object->usage_organize_event ?
' checked="checked"' :
'')).
'"> ';
404 $htmltext = $langs->trans(
"EventOrganizationDescriptionLong");
405 print $form->textwithpicto($langs->trans(
"ManageOrganizeEvent"), $htmltext);
412 print
'<tr><td>'.$langs->trans(
"OpportunityStatus").
'</td><td>';
415 print $langs->trans(
"OppStatus".$code);
419 print
' <span title="'.$langs->trans(
"OpportunityProbability").
'"> / ';
420 if (strcmp(
$object->opp_percent,
'')) {
421 print
price(
$object->opp_percent, 0, $langs, 1, 0).
' %';
423 print
'</span></td></tr>';
426 print
'<tr><td>'.$langs->trans(
"OpportunityAmount").
'</td><td>';
427 if (!is_null(
$object->opp_amount) && strcmp(
$object->opp_amount,
'')) {
428 print
'<span class="amount">'.price(
$object->opp_amount, 0, $langs, 1, 0, 0, $conf->currency).
'</span>';
429 if (strcmp(
$object->opp_percent,
'')) {
430 print
' <span title="'.dol_escape_htmltag($langs->trans(
'OpportunityWeightedAmount')).
'"><span class="opacitymedium">'.$langs->trans(
"OpportunityWeightedAmountShort").
'</span>: <span class="amount">'.
price(
$object->opp_amount *
$object->opp_percent / 100, 0, $langs, 1, 0, -1, $conf->currency).
'</span></span>';
437print
'<tr><td>'.$langs->trans(
"Budget").
'</td><td>';
438if (!is_null(
$object->budget_amount) && strcmp(
$object->budget_amount,
'')) {
439 print
'<span class="amount">'.price(
$object->budget_amount, 0, $langs, 1, 0, 0, $conf->currency).
'</span>';
444print
'<tr><td>'.$langs->trans(
"Dates").
'</td><td>';
446print($start ? $start :
'?');
449print($end ? $end :
'?');
456print
'<tr><td class="titlefield">'.$langs->trans(
"Visibility").
'</td><td>';
458 print
img_picto($langs->trans(
'SharedProject'),
'world',
'class="paddingrightonly"');
459 print $langs->trans(
'SharedProject');
461 print
img_picto($langs->trans(
'PrivateProject'),
'private',
'class="paddingrightonly"');
462 print $langs->trans(
'PrivateProject');
468include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_view.tpl.php';
473print
'<div class="fichehalfright">';
474print
'<div class="underbanner clearboth"></div>';
476print
'<table class="border tableforfield centpercent">';
480 print
'<tr><td class="valignmiddle">'.$langs->trans(
"Categories").
'</td><td>';
481 print $form->showCategories(
$object->id, Categorie::TYPE_PROJECT, 1);
486print
'<tr><td class="titlefield'.($object->description ?
' noborderbottom' :
'').
'" colspan="2">'.$langs->trans(
"Description").
'</td></tr>';
488 print
'<tr><td class="nottitleforfield" colspan="2">';
489 print
'<div class="longmessagecut">';
500print
'<div class="clearboth"></div>';
510$listofreferent = array(
512 'name' =>
"Warehouse",
513 'title' =>
"ListWarehouseAssociatedProject",
514 'class' =>
'Entrepot',
515 'table' =>
'entrepot',
516 'datefieldname' =>
'date_entrepot',
517 'urlnew' => DOL_URL_ROOT.
'/product/stock/card.php?action=create&projectid='.
$id.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
518 'lang' =>
'entrepot',
519 'buttonnew' =>
'AddWarehouse',
520 'project_field' =>
'fk_project',
521 'testnew' => $user->hasRight(
'stock',
'creer'),
525 'name' =>
"Proposals",
526 'title' =>
"ListProposalsAssociatedProject",
529 'datefieldname' =>
'datep',
530 'urlnew' => DOL_URL_ROOT.
'/comm/propal/card.php?action=create&origin=project&originid='.
$id.
'&socid='.$socid.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
532 'buttonnew' =>
'AddProp',
533 'testnew' => $user->hasRight(
'propal',
'creer'),
534 'test' =>
isModEnabled(
'propal') && $user->hasRight(
'propal',
'lire')
537 'name' =>
"CustomersOrders",
538 'title' =>
"ListOrdersAssociatedProject",
539 'class' =>
'Commande',
540 'table' =>
'commande',
541 'datefieldname' =>
'date_commande',
542 'urlnew' => DOL_URL_ROOT.
'/commande/card.php?action=create&projectid='.
$id.
'&socid='.$socid.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
544 'buttonnew' =>
'CreateOrder',
545 'testnew' => $user->hasRight(
'commande',
'creer'),
546 'test' =>
isModEnabled(
'order') && $user->hasRight(
'commande',
'lire')
549 'name' =>
"CustomersInvoices",
550 'title' =>
"ListInvoicesAssociatedProject",
551 'class' =>
'Facture',
553 'table' =>
'facture',
554 'datefieldname' =>
'datef',
555 'urlnew' => DOL_URL_ROOT.
'/compta/facture/card.php?action=create&projectid='.
$id.
'&socid='.$socid.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
557 'buttonnew' =>
'CreateBill',
558 'testnew' => $user->hasRight(
'facture',
'creer'),
559 'test' =>
isModEnabled(
'invoice') && $user->hasRight(
'facture',
'lire')
561 'invoice_predefined' => array(
562 'name' =>
"PredefinedInvoices",
563 'title' =>
"ListPredefinedInvoicesAssociatedProject",
564 'class' =>
'FactureRec',
565 'table' =>
'facture_rec',
566 'datefieldname' =>
'datec',
567 'urlnew' => DOL_URL_ROOT.
'/compta/facture/card.php?action=create&projectid='.
$id.
'&socid='.$socid.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
569 'buttonnew' =>
'CreateBill',
570 'testnew' => $user->hasRight(
'facture',
'creer'),
571 'test' =>
isModEnabled(
'invoice') && $user->hasRight(
'facture',
'lire')
573 'proposal_supplier' => array(
574 'name' =>
"SupplierProposals",
575 'title' =>
"ListSupplierProposalsAssociatedProject",
576 'class' =>
'SupplierProposal',
577 'table' =>
'supplier_proposal',
578 'datefieldname' =>
'date_valid',
579 'urlnew' => DOL_URL_ROOT.
'/supplier_proposal/card.php?action=create&projectid='.
$id.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
580 'lang' =>
'supplier_proposal',
581 'buttonnew' =>
'AddSupplierProposal',
582 'testnew' => $user->hasRight(
'supplier_proposal',
'creer'),
583 'test' =>
isModEnabled(
'supplier_proposal') && $user->hasRight(
'supplier_proposal',
'lire')
585 'order_supplier' => array(
586 'name' =>
"SuppliersOrders",
587 'title' =>
"ListSupplierOrdersAssociatedProject",
588 'class' =>
'CommandeFournisseur',
589 'table' =>
'commande_fournisseur',
590 'datefieldname' =>
'date_commande',
591 'urlnew' => DOL_URL_ROOT.
'/fourn/commande/card.php?action=create&projectid='.
$id.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
592 'lang' =>
'suppliers',
593 'buttonnew' =>
'AddSupplierOrder',
594 'testnew' => $user->hasRight(
'fournisseur',
'commande',
'creer') || $user->hasRight(
'supplier_order',
'creer'),
595 'test' =>
isModEnabled(
'supplier_order') && $user->hasRight(
'fournisseur',
'commande',
'lire') || $user->hasRight(
'supplier_order',
'lire')
597 'invoice_supplier' => array(
598 'name' =>
"BillsSuppliers",
599 'title' =>
"ListSupplierInvoicesAssociatedProject",
600 'class' =>
'FactureFournisseur',
602 'table' =>
'facture_fourn',
603 'datefieldname' =>
'datef',
604 'urlnew' => DOL_URL_ROOT.
'/fourn/facture/card.php?action=create&projectid='.
$id.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
605 'lang' =>
'suppliers',
606 'buttonnew' =>
'AddSupplierInvoice',
607 'testnew' => $user->hasRight(
'fournisseur',
'facture',
'creer') || $user->hasRight(
'supplier_invoice',
'creer'),
608 'test' =>
isModEnabled(
'supplier_invoice') && $user->hasRight(
'fournisseur',
'facture',
'lire') || $user->hasRight(
'supplier_invoice',
'lire')
611 'name' =>
"Contracts",
612 'title' =>
"ListContractAssociatedProject",
613 'class' =>
'Contrat',
614 'table' =>
'contrat',
615 'datefieldname' =>
'date_contrat',
616 'urlnew' => DOL_URL_ROOT.
'/contrat/card.php?action=create&projectid='.
$id.
'&socid='.$socid.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
617 'lang' =>
'contracts',
618 'buttonnew' =>
'AddContract',
619 'testnew' => $user->hasRight(
'contrat',
'creer'),
620 'test' =>
isModEnabled(
'contract') && $user->hasRight(
'contrat',
'lire')
622 'intervention' => array(
623 'name' =>
"Interventions",
624 'title' =>
"ListFichinterAssociatedProject",
625 'class' =>
'Fichinter',
626 'table' =>
'fichinter',
627 'datefieldname' =>
'date_valid',
628 'disableamount' => 0,
630 'urlnew' => DOL_URL_ROOT.
'/fichinter/card.php?action=create&origin=project&originid='.
$id.
'&socid='.$socid.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
631 'lang' =>
'interventions',
632 'buttonnew' =>
'AddIntervention',
633 'testnew' => $user->hasRight(
'ficheinter',
'creer'),
634 'test' =>
isModEnabled(
'intervention') && $user->hasRight(
'ficheinter',
'lire')
637 'name' =>
"Shippings",
638 'title' =>
"ListShippingAssociatedProject",
639 'class' =>
'Expedition',
640 'table' =>
'expedition',
641 'datefieldname' =>
'date_valid',
642 'urlnew' => DOL_URL_ROOT.
'/expedition/card.php?action=create&origin=project&originid='.
$id.
'&socid='.$socid.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
643 'lang' =>
'sendings',
644 'buttonnew' =>
'CreateShipment',
646 'test' =>
isModEnabled(
'shipping') && $user->hasRight(
'expedition',
'lire')
650 'title' =>
"ListMOAssociatedProject",
653 'datefieldname' =>
'date_valid',
654 'urlnew' => DOL_URL_ROOT.
'/mrp/mo_card.php?action=create&origin=project&originid='.
$id.
'&socid='.$socid.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
656 'buttonnew' =>
'CreateMO',
657 'testnew' => $user->hasRight(
'mrp',
'write'),
658 'project_field' =>
'fk_project',
660 'test' =>
isModEnabled(
'mrp') && $user->hasRight(
'mrp',
'read')
663 'name' =>
"TripsAndExpenses",
664 'title' =>
"ListExpenseReportsAssociatedProject",
665 'class' =>
'Deplacement',
666 'table' =>
'deplacement',
667 'datefieldname' =>
'dated',
669 'disableamount' => 1,
670 'urlnew' => DOL_URL_ROOT.
'/deplacement/card.php?action=create&projectid='.
$id.
'&socid='.$socid.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
672 'buttonnew' =>
'AddTrip',
673 'testnew' => $user->hasRight(
'deplacement',
'creer'),
674 'test' =>
isModEnabled(
'deplacement') && $user->hasRight(
'deplacement',
'lire')
676 'expensereport' => array(
677 'name' =>
"ExpenseReports",
678 'title' =>
"ListExpenseReportsAssociatedProject",
679 'class' =>
'ExpenseReportLine',
680 'table' =>
'expensereport_det',
681 'datefieldname' =>
'date',
683 'disableamount' => 0,
684 'urlnew' => DOL_URL_ROOT.
'/expensereport/card.php?action=create&projectid='.
$id.
'&socid='.$socid.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
686 'buttonnew' =>
'AddTrip',
687 'testnew' => $user->hasRight(
'expensereport',
'creer'),
688 'test' =>
isModEnabled(
'expensereport') && $user->hasRight(
'expensereport',
'lire')
691 'name' =>
"Donation",
692 'title' =>
"ListDonationsAssociatedProject",
696 'datefieldname' =>
'datedon',
697 'disableamount' => 0,
698 'urlnew' => DOL_URL_ROOT.
'/don/card.php?action=create&projectid='.
$id.
'&socid='.$socid.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
699 'lang' =>
'donations',
700 'buttonnew' =>
'AddDonation',
701 'testnew' => $user->hasRight(
'don',
'creer'),
702 'test' =>
isModEnabled(
'don') && $user->hasRight(
'don',
'lire')
706 'title' =>
"ListLoanAssociatedProject",
710 'datefieldname' =>
'datestart',
711 'disableamount' => 0,
712 'urlnew' => DOL_URL_ROOT.
'/loan/card.php?action=create&projectid='.
$id.
'&socid='.$socid.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
714 'buttonnew' =>
'AddLoan',
715 'testnew' => $user->hasRight(
'loan',
'write'),
716 'test' =>
isModEnabled(
'loan') && $user->hasRight(
'loan',
'read')
718 'chargesociales' => array(
719 'name' =>
"SocialContribution",
720 'title' =>
"ListSocialContributionAssociatedProject",
721 'class' =>
'ChargeSociales',
723 'table' =>
'chargesociales',
724 'datefieldname' =>
'date_ech',
725 'disableamount' => 0,
726 'urlnew' => DOL_URL_ROOT.
'/compta/sociales/card.php?action=create&projectid='.
$id.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.$id),
728 'buttonnew' =>
'AddSocialContribution',
729 'testnew' => $user->hasRight(
'tax',
'charges',
'lire'),
730 'test' =>
isModEnabled(
'tax') && $user->hasRight(
'tax',
'charges',
'lire')
732 'project_task' => array(
733 'name' =>
"TaskTimeSpent",
734 'title' =>
"ListTaskTimeUserProject",
737 'table' =>
'projet_task',
738 'datefieldname' =>
'element_date',
739 'disableamount' => ($canSeeFinancials ? 0 : 1),
740 'urlnew' => DOL_URL_ROOT.
'/projet/tasks/time.php?withproject=1&action=createtime&projectid='.
$id.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.
$id),
741 'buttonnew' =>
'AddTimeSpent',
742 'testnew' => $user->hasRight(
'project',
'creer'),
745 'stock_mouvement' => array(
746 'name' =>
"MouvementStockAssociated",
747 'title' =>
"ListMouvementStockProject",
748 'class' =>
'StockTransfer',
749 'table' =>
'stocktransfer_stocktransfer',
750 'datefieldname' =>
'datem',
752 'project_field' =>
'fk_project',
753 'disableamount' => 0,
757 'name' =>
"Salaries",
758 'title' =>
"ListSalariesAssociatedProject",
761 'datefieldname' =>
'datesp',
763 'disableamount' => 0,
764 'urlnew' => DOL_URL_ROOT.
'/salaries/card.php?action=create&projectid='.
$id.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.
$id),
765 'lang' =>
'salaries',
766 'buttonnew' =>
'AddSalary',
767 'testnew' => $user->hasRight(
'salaries',
'write'),
768 'test' =>
isModEnabled(
'salaries') && $user->hasRight(
'salaries',
'read')
770 'variouspayment' => array(
771 'name' =>
"VariousPayments",
772 'title' =>
"ListVariousPaymentsAssociatedProject",
773 'class' =>
'PaymentVarious',
774 'table' =>
'payment_various',
775 'datefieldname' =>
'datev',
777 'disableamount' => 0,
778 'urlnew' => DOL_URL_ROOT.
'/compta/bank/various_payment/card.php?action=create&projectid='.
$id.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF'].
'?id='.
$id),
780 'buttonnew' =>
'AddVariousPayment',
781 'testnew' => $user->hasRight(
'banque',
'modifier'),
802 foreach ($listofreferent as $key => $element) {
803 if ($listofreferent[$key][
'margin'] ==
'add') {
804 unset($listofreferent[$key][
'margin']);
807 $newelementforplusmargin = explode(
',',
getDolGlobalString(
'PROJECT_ELEMENTS_FOR_PLUS_MARGIN'));
808 foreach ($newelementforplusmargin as $value) {
809 $listofreferent[trim($value)][
'margin'] =
'add';
813 foreach ($listofreferent as $key => $element) {
814 if ($listofreferent[$key][
'margin'] ==
'minus') {
815 unset($listofreferent[$key][
'margin']);
818 $newelementforminusmargin = explode(
',',
getDolGlobalString(
'PROJECT_ELEMENTS_FOR_MINUS_MARGIN'));
819 foreach ($newelementforminusmargin as $value) {
820 $listofreferent[trim($value)][
'margin'] =
'minus';
825$parameters = array(
'listofreferent' => $listofreferent);
826$resHook = $hookmanager->executeHooks(
'completeListOfReferent', $parameters, $object, $action);
828if (!empty($hookmanager->resArray)) {
829 $listofreferent = array_merge($listofreferent, $hookmanager->resArray);
830} elseif ($resHook > 0 && !empty($hookmanager->resPrint)) {
831 $listofreferent = $hookmanager->resPrint;
834if ($action ==
"addelement") {
835 $tablename =
GETPOST(
"tablename",
"aZ09");
836 $elementselectid =
GETPOSTINT(
"elementselect");
837 $result =
$object->update_element($tablename, $elementselectid);
841} elseif ($action ==
"unlink") {
842 $tablename =
GETPOST(
"tablename",
"aZ09");
843 $projectField = GETPOSTISSET(
'projectfield') ?
GETPOST(
'projectfield',
'aZ09') :
'fk_projet';
844 $elementselectid =
GETPOSTINT(
"elementselect");
846 $result =
$object->remove_element($tablename, $elementselectid, $projectField);
852$elementuser =
new User($db);
858if (!$showdatefilter) {
859 print
'<div class="center centpercent">';
860 print
'<form action="'.$_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'" method="POST">';
861 print
'<input type="hidden" name="token" value="'.newToken().
'">';
862 print
'<input type="hidden" name="tablename" value="'.(empty($tablename) ?
'' : $tablename).
'">';
863 print
'<input type="hidden" name="action" value="view">';
864 print
'<div class="inline-block">';
865 print $form->selectDate($dates,
'dates', 0, 0, 1,
'', 1, 0, 0,
'',
'',
'',
'', 1,
'', $langs->trans(
"From"));
867 print
'<div class="inline-block">';
868 print $form->selectDate($datee,
'datee', 0, 0, 1,
'', 1, 0, 0,
'',
'',
'',
'', 1,
'', $langs->trans(
"to"));
870 print
'<div class="inline-block">';
871 print
'<input type="submit" name="refresh" value="'.$langs->trans(
"Refresh").
'" class="button small">';
883$langs->loadLangs(array(
"suppliers",
"bills",
"orders",
"proposals",
"margins"));
886 $langs->load(
'stocks');
889print
'<!-- Begin PROFIT table -->';
892print
'<div class="div-table-responsive">';
893print
'<table class="noborder centpercent">';
894print
'<tr class="liste_titre">';
895print
'<td class="left" width="200">';
896$tooltiponprofit = $langs->trans(
"ProfitIsCalculatedWith").
"<br>\n";
897$tooltiponprofitplus = $tooltiponprofitminus =
'';
898foreach ($listofreferent as $key => $value) {
899 if (!empty($value[
'lang'])) {
900 $langs->load($value[
'lang']);
902 $name = $langs->trans($value[
'name']);
903 $qualified = $value[
'test'];
904 $margin = empty($value[
'margin']) ?
'' : $value[
'margin'];
905 if ($qualified && $margin) {
906 if ($margin ===
'add') {
907 $tooltiponprofitplus .=
' > '.$name.
" (+)<br>\n";
908 } elseif ($margin ===
'minus') {
909 $tooltiponprofitminus .=
' > '.$name.
" (-)<br>\n";
913$tooltiponprofit .= $tooltiponprofitplus;
914$tooltiponprofit .= $tooltiponprofitminus;
915print $form->textwithpicto($langs->trans(
"Element"), $tooltiponprofit);
917print
'<td class="right" width="100">'.$langs->trans(
"Number").
'</td>';
918print
'<td class="right" width="100">'.$langs->trans(
"AmountHT").
'</td>';
919print
'<td class="right" width="100">'.$langs->trans(
"AmountTTC").
'</td>';
922$total_revenue_ht = 0;
927foreach ($listofreferent as $key => $value) {
929 'total_revenue_ht' => & $total_revenue_ht,
930 'balance_ht' => & $balance_ht,
931 'balance_ttc' => & $balance_ttc,
937 $reshook = $hookmanager->executeHooks(
'printOverviewProfit', $parameters, $object, $action);
940 } elseif ($reshook > 0) {
941 print $hookmanager->resPrint;
945 $name = $langs->trans($value[
'name']);
946 $title = $value[
'title'];
947 $classname = $value[
'class'];
948 $tablename = $value[
'table'];
949 $datefieldname = $value[
'datefieldname'];
950 $qualified = $value[
'test'];
952 if ($key ===
'project_task' && !$canSeeFinancials) {
955 $margin = empty($value[
'margin']) ? 0 : $value[
'margin'];
956 $project_field = empty($value[
'project_field']) ?
'' : $value[
'project_field'];
958 $element =
new $classname($db);
960 $elementarray =
$object->get_element_list($key, $tablename, $datefieldname, $dates, $datee, !empty($project_field) ? $project_field :
'fk_projet');
962 if (is_array($elementarray) && count($elementarray) > 0) {
968 $num = count($elementarray);
969 for ($i = 0; $i < $num; $i++) {
970 $tmp = explode(
'_', $elementarray[$i]);
971 $idofelement = (int) $tmp[0];
972 $idofelementuser = !empty($tmp[1]) ? (int) $tmp[1] : 0;
974 $element->fetch($idofelement);
975 if ($idofelementuser) {
976 $elementuser->fetch($idofelementuser);
980 $qualifiedfortotal =
true;
981 if ($key ==
'invoice') {
982 if (!empty($element->close_code) && $element->close_code ==
'replaced') {
983 $qualifiedfortotal =
false;
986 $qualifiedfortotal =
false;
989 if ($key ==
'propal') {
991 $qualifiedfortotal =
false;
995 if ($tablename !=
'expensereport_det' && method_exists($element,
'fetch_thirdparty')) {
996 $element->fetch_thirdparty();
1000 if ($tablename ==
'don' || $tablename ==
'chargesociales' || $tablename ==
'payment_various' || $tablename ==
'salary') {
1001 '@phan-var-force ChargeSociales|PaymentVarious|Salary $element';
1002 $total_ht_by_line = $element->amount;
1003 } elseif ($tablename ==
'fichinter') {
1004 '@phan-var-force Fichinter $element';
1005 $total_ht_by_line = $element->getAmount();
1006 } elseif ($tablename ==
'stock_mouvement') {
1007 '@phan-var-force MouvementStock $element';
1008 $total_ht_by_line = $element->price * abs($element->qty);
1009 } elseif ($tablename ==
'projet_task') {
1010 '@phan-var-force Task $element';
1011 $tmp = $element->getSumOfAmount($idofelementuser ? $elementuser :
'', (string) $dates, (string) $datee);
1012 $total_ht_by_line =
price2num($tmp[
'amount'],
'MT');
1013 } elseif ($key ==
'loan') {
1014 '@phan-var-force Loan $element';
1015 if ((empty($dates) && empty($datee)) || (intval($dates) <= $element->datestart && intval($datee) >= $element->dateend)) {
1017 $total_ht_by_line = -$element->capital;
1020 $total_ht_by_line = 0;
1022 $loanScheduleStatic->fetchAll($element->id);
1023 if (!empty($loanScheduleStatic->lines)) {
1024 foreach ($loanScheduleStatic->lines as $loanSchedule) {
1028 if (($loanSchedule->datep >= $dates && $loanSchedule->datep <= $datee)
1029 || !empty($dates) && empty($datee) && $loanSchedule->datep >= $dates && $loanSchedule->datep <=
dol_now()
1030 || empty($dates) && !empty($datee) && $loanSchedule->datep <= $datee
1032 $total_ht_by_line -= $loanSchedule->amount_capital;
1038 $total_ht_by_line = $element->total_ht;
1042 if ($tablename ==
'don' || $tablename ==
'chargesociales' || $tablename ==
'payment_various' || $tablename ==
'salary') {
1043 '@phan-var-force ChargeSociales|PaymentVarious|Salary $element';
1044 $total_ttc_by_line = $element->amount;
1045 } elseif ($tablename ==
'fichinter') {
1046 '@phan-var-force Fichinter $element';
1047 $total_ttc_by_line = $element->getAmount();
1048 } elseif ($tablename ==
'stock_mouvement') {
1049 '@phan-var-force MouvementStock $element';
1050 $total_ttc_by_line = $element->price * abs($element->qty);
1051 } elseif ($tablename ==
'projet_task') {
1052 '@phan-var-force Task $element';
1055 if (preg_replace(
'/^(\d+\.)\s\(.*\)/', $defaultvat, $reg)) {
1057 $defaultvat = $reg[1];
1059 $total_ttc_by_line =
price2num($total_ht_by_line * (1 + ((
float) $defaultvat / 100)),
'MT');
1060 } elseif ($key ==
'loan') {
1061 $total_ttc_by_line = $total_ht_by_line;
1063 $total_ttc_by_line = $element->total_ttc;
1067 if ($tablename ==
'payment_various') {
1068 if ($element->sens == 1) {
1069 $total_ht_by_line = -$total_ht_by_line;
1070 $total_ttc_by_line = -$total_ttc_by_line;
1078 if (($tablename ==
'commande_fournisseur' || $tablename ==
'supplier_proposal') && $margin !==
'minus') {
1079 $total_ht_by_line = -$total_ht_by_line;
1080 $total_ttc_by_line = -$total_ttc_by_line;
1084 if ($qualifiedfortotal) {
1085 $total_ht += $total_ht_by_line;
1086 $total_ttc += $total_ttc_by_line;
1094 if ($margin ===
'add') {
1095 $total_revenue_ht += $total_ht;
1098 if ($margin ===
"minus") {
1099 $total_ht = -$total_ht;
1100 $total_ttc = -$total_ttc;
1103 $balance_ht += $total_ht;
1104 $balance_ttc += $total_ttc;
1107 print
'<tr class="oddeven">';
1109 print
'<!-- // Module '.$name.
' with tablename '.$tablename.
' -->';
1110 print
'<td class="left"><a href="#table_'.$tablename.
'">'.$name.
'</a></td>';
1112 print
'<td class="right">'.$i.
'</td>';
1114 print
'<td class="right">';
1115 if ($key ==
'intervention' && !$margin) {
1116 print
'<span class="opacitymedium">'.$form->textwithpicto($langs->trans(
"NA"), $langs->trans(
"AmountOfInteventionNotIncludedByDefault")).
'</span>';
1118 if ($key ==
'propal') {
1119 print
'<span class="opacitymedium">'.$form->textwithpicto(
'', $langs->trans(
"SignedOnly")).
'</span>';
1121 print
price($total_ht);
1125 print
'<td class="right">';
1126 if ($key ==
'intervention' && !$margin) {
1127 print
'<span class="opacitymedium">'.$form->textwithpicto($langs->trans(
"NA"), $langs->trans(
"AmountOfInteventionNotIncludedByDefault")).
'</span>';
1129 if ($key ==
'propal') {
1130 print
'<span class="opacitymedium">'.$form->textwithpicto(
'', $langs->trans(
"SignedOnly")).
'</span>';
1132 print
price($total_ttc);
1140print
'<tr class="liste_total">';
1141print
'<td class="right" colspan="2">'.$langs->trans(
"Profit").
'</td>';
1142print
'<td class="right">'.price(
price2num($balance_ht,
'MT')).
'</td>';
1143print
'<td class="right">'.price(
price2num($balance_ttc,
'MT')).
'</td>';
1147if (
$object->usage_organize_event) {
1148 require_once DOL_DOCUMENT_ROOT.
'/eventorganization/class/conferenceorboothattendee.class.php';
1150 $result = $conforboothattendee->fetchAll(
'',
'', 0, 0,
'(t.fk_project:=:'.((
int)
$object->id).
') AND (t.status:=:'.ConferenceOrBoothAttendee::STATUS_VALIDATED.
')');
1152 if (!is_array($result) && $result < 0) {
1153 setEventMessages($conforboothattendee->error, $conforboothattendee->errors,
'errors');
1155 $nbAttendees = count($result);
1158 if ($nbAttendees >= 2) {
1159 $costperattendee_ht = $balance_ht / $nbAttendees;
1160 $costperattendee_ttc = $balance_ttc / $nbAttendees;
1161 print
'<tr class="liste_total">';
1162 print
'<td class="right" colspan="2">'.$langs->trans(
"ProfitPerValidatedAttendee").
'</td>';
1163 print
'<td class="right">'.price(
price2num($costperattendee_ht,
'MT')).
'</td>';
1164 print
'<td class="right">'.price(
price2num($costperattendee_ttc,
'MT')).
'</td>';
1170if ($total_revenue_ht) {
1171 print
'<tr class="liste_total">';
1172 print
'<td class="right" colspan="2">'.$langs->trans(
"Margin").
'</td>';
1173 print
'<td class="right">'.round(100 * $balance_ht / $total_revenue_ht, 1).
'%</td>';
1174 print
'<td class="right"></td>';
1180print
'<!-- End PROFIT table -->';
1190foreach ($listofreferent as $key => $value) {
1191 $parameters = array(
1193 'value' => & $value,
1197 $reshook = $hookmanager->executeHooks(
'printOverviewDetail', $parameters, $object, $action);
1200 } elseif ($reshook > 0) {
1201 print $hookmanager->resPrint;
1205 $title = $value[
'title'];
1206 $classname = $value[
'class'];
1207 $tablename = $value[
'table'];
1208 $datefieldname = $value[
'datefieldname'];
1209 $qualified = $value[
'test'];
1210 $urlnew = empty($value[
'urlnew']) ?
'' : $value[
'urlnew'];
1211 $buttonnew = empty($value[
'buttonnew']) ?
'' : $value[
'buttonnew'];
1212 $testnew = empty($value[
'testnew']) ?
'' : $value[
'testnew'];
1213 $project_field = empty($value[
'project_field']) ?
'' : $value[
'project_field'];
1214 $nototal = empty($value[
'nototal']) ? 0 : 1;
1216 $exclude_select_element = array(
'payment_various');
1217 if (!empty($value[
'exclude_select_element'])) {
1218 $exclude_select_element[] = $value[
'exclude_select_element'];
1221 if ($qualified && $tablename !==
null) {
1225 $element =
new $classname($db);
1229 $idtofilterthirdparty = 0;
1230 $array_of_element_linkable_with_different_thirdparty = array(
'facture_fourn',
'commande_fournisseur');
1231 if (!in_array($tablename, $array_of_element_linkable_with_different_thirdparty)) {
1232 $idtofilterthirdparty = empty(
$object->thirdparty->id) ? 0 :
$object->thirdparty->id;
1234 $idtofilterthirdparty .=
',' .
getDolGlobalString(
'PROJECT_OTHER_THIRDPARTY_ID_TO_ADD_ELEMENTS');
1238 $elementarray =
$object->get_element_list($key, $tablename, $datefieldname, $dates, $datee, !empty($project_field) ? $project_field :
'fk_projet');
1241 if (!
getDolGlobalString(
'PROJECT_LINK_ON_OVERWIEW_DISABLED') && $idtofilterthirdparty && !in_array($tablename, $exclude_select_element)) {
1242 $selectList = $formproject->select_element($tablename, $idtofilterthirdparty,
'minwidth300 minwidth75imp', -2, empty($project_field) ?
'fk_projet' : $project_field, $langs->trans(
"SelectElement"));
1243 if ((
int) $selectList < 0) {
1245 } elseif ($selectList) {
1247 $addform .=
'<div class="inline-block valignmiddle">';
1248 $addform .=
'<form action="'.$_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'" method="post">';
1249 $addform .=
'<input type="hidden" name="token" value="'.newToken().
'">';
1250 $addform .=
'<input type="hidden" name="tablename" value="'.$tablename.
'">';
1251 $addform .=
'<input type="hidden" name="action" value="addelement">';
1252 $addform .=
'<input type="hidden" name="datesrfc" value="'.dol_print_date($dates,
'dayhourrfc').
'">';
1253 $addform .=
'<input type="hidden" name="dateerfc" value="'.dol_print_date($datee,
'dayhourrfc').
'">';
1254 $addform .=
'<table><tr>';
1256 $addform .=
'<td>'.$selectList.
'</td>';
1257 $addform .=
'<td><input type="submit" class="button button-linkto smallpaddingimp" value="'.dol_escape_htmltag($langs->trans(
"LinkToElementShort")).
'"></td>';
1258 $addform .=
'</tr></table>';
1259 $addform .=
'</form>';
1260 $addform .=
'</div>';
1264 $addform .=
'<div class="inline-block valignmiddle">';
1266 $addform .=
'<a class="buttonxxx marginleftonly" href="'.$urlnew.
'" title="'.
dol_escape_htmltag($langs->trans($buttonnew)).
'"><span class="fa fa-plus-circle valignmiddle paddingleft"></span></a>';
1268 $addform .=
'<span title="'.dol_escape_htmltag($langs->trans($buttonnew)).
'"><a class="buttonxxx marginleftonly buttonRefused" disabled="disabled" href="#"><span class="fa fa-plus-circle valignmiddle paddingleft"></span></a></span>';
1270 $addform .=
'<div>';
1273 if (is_array($elementarray) && count($elementarray) > 0 && $key ==
"order_supplier") {
1274 $addform .=
'<div class="inline-block valignmiddle"><a id="btnShow" class="buttonxxx marginleftonly" href="#" onClick="return false;">
1275 <span id="textBtnShow" class="valignmiddle text-plus-circle hideonsmartphone">'.$langs->trans(
"CanceledShown").
'</span><span id="minus-circle" class="fa fa-eye valignmiddle paddingleft"></span>
1278 $("#btnShow").on("click", function () {
1279 console.log("We click to show or hide the canceled lines");
1280 var attr = $(this).attr("data-canceledarehidden");
1281 if (typeof attr !== "undefined" && attr !== false) {
1282 console.log("Show canceled");
1283 $(".tr_canceled").show();
1284 $("#textBtnShow").text("'.
dol_escape_js($langs->transnoentitiesnoconv(
"CanceledShown")).
'");
1285 $("#btnShow").removeAttr("data-canceledarehidden");
1286 $("#minus-circle").removeClass("fa-eye-slash").addClass("fa-eye");
1288 console.log("Hide canceled");
1289 $(".tr_canceled").hide();
1290 $("#textBtnShow").text("'.
dol_escape_js($langs->transnoentitiesnoconv(
"CanceledHidden")).
'");
1291 $("#btnShow").attr("data-canceledarehidden", 1);
1292 $("#minus-circle").removeClass("fa-eye").addClass("fa-eye-slash");
1297 $addform .=
'<div class="inline-block valignmiddle"><a id="btnShowPaid" class="buttonxxx marginleftonly" href="#" onClick="return false;">
1298 <span id="textBtnShowPaid" class="valignmiddle text-plus-circle hideonsmartphone">'.$langs->trans(
"PaidShown").
'</span><span id="minus-circle-paid" class="fa fa-eye valignmiddle paddingleft"></span>
1301 $("#btnShowPaid").on("click", function () {
1302 console.log("We click to show or hide the paid lines");
1303 var attr = $(this).attr("data-paidarehidden");
1304 if (typeof attr !== "undefined" && attr !== false) {
1305 console.log("Show paid");
1306 $(".tr_paid").show();
1307 $("#textBtnShowPaid").text("'.
dol_escape_js($langs->transnoentitiesnoconv(
"PaidShown")).
'");
1308 $("#btnShowPaid").removeAttr("data-paidarehidden");
1309 $("#minus-circle-paid").removeClass("fa-eye-slash").addClass("fa-eye");
1311 console.log("Hide paid");
1312 $(".tr_paid").hide();
1313 $("#textBtnShowPaid").text("'.
dol_escape_js($langs->transnoentitiesnoconv(
"PaidHidden")).
'");
1314 $("#btnShowPaid").attr("data-paidarehidden", 1);
1315 $("#minus-circle-paid").removeClass("fa-eye").addClass("fa-eye-slash");
1321 print
'<a id="table_'.$tablename.
'"></a>';
1324 print
"\n".
'<!-- Table for tablename = '.$tablename.
' -->'.
"\n";
1325 print
'<div class="div-table-responsive">';
1326 print
'<table class="noborder centpercent">';
1328 print
'<tr class="liste_titre">';
1330 print
'<td style="width: 24px"></td>';
1332 print
'<td'.(($tablename !=
'actioncomm' && $tablename !=
'projet_task') ?
' style="width: 200px"' :
'').
'>'.$langs->trans(
"Ref").
'</td>';
1334 if (
'MouvementStock' == $classname) {
1335 print
'<td style="width: 200px">'.$langs->trans(
"Product").
'</td>';
1336 print
'<td style="width: 50px">'.$langs->trans(
"Qty").
'</td>';
1339 print
'<td'.(($tablename !=
'actioncomm' && $tablename !=
'projet_task') ?
' style="width: 200px"' :
'').
' class="center">';
1340 if (in_array($tablename, array(
'projet_task'))) {
1341 print $langs->trans(
"TimeSpent");
1343 if (!in_array($tablename, array(
'projet_task'))) {
1344 print $langs->trans(
"Date");
1349 if (in_array($tablename, array(
'projet_task')) && $key ==
'project_task') {
1351 } elseif (in_array($tablename, array(
'payment_various'))) {
1352 print $langs->trans(
"Label");
1353 } elseif (in_array($tablename, array(
'expensereport_det',
'don',
'projet_task',
'stock_mouvement',
'salary'))) {
1354 print $langs->trans(
"User");
1356 print $langs->trans(
"ThirdParty");
1360 if ($tablename ==
'fichinter') {
1362 print $langs->trans(
"TotalDuration");
1363 $total_duration = 0;
1367 if ($tablename ==
'expensereport_det') {
1368 print
'<td id="expensereport_type">';
1369 print $langs->trans(
"Type");
1373 if ($tablename ==
'expensereport_det') {
1374 print
'<td id="expensereport_description">';
1375 print $langs->trans(
"Description");
1383 if ($key ==
'loan') {
1384 print
'<td class="right" width="120">'.$langs->trans(
"LoanCapital").
'</td>';
1385 } elseif (empty($value[
'disableamount'])) {
1386 print
'<td class="right" width="120">'.$langs->trans(
"AmountHT").
'</td>';
1388 print
'<td width="120"></td>';
1392 if ($key ==
'loan') {
1393 print
'<td class="right" width="120">'.$langs->trans(
"RemainderToPay").
'</td>';
1394 } elseif (empty($value[
'disableamount'])) {
1395 print
'<td class="right" width="120">'.$langs->trans(
"AmountTTC").
'</td>';
1397 print
'<td width="120"></td>';
1400 if (in_array($tablename, array(
'projet_task'))) {
1401 print
'<td class="right" width="200">'.$langs->trans(
"ProgressDeclared").
'</td>';
1403 print
'<td class="right" width="200">'.$langs->trans(
"Status").
'</td>';
1407 if (is_array($elementarray) && count($elementarray) > 0) {
1412 $total_ht_by_third = 0;
1413 $total_ttc_by_third = 0;
1415 $saved_third_id = 0;
1423 $num = count($elementarray);
1425 for ($i = 0; $i < $num; $i++) {
1426 $tmp = explode(
'_', $elementarray[$i]);
1427 $idofelement = (int) $tmp[0];
1428 $idofelementuser = isset($tmp[1]) ? (int) $tmp[1] : 0;
1430 $element->fetch($idofelement);
1431 if ($idofelementuser) {
1432 $elementuser->fetch($idofelementuser);
1436 if ($tablename !=
'expensereport_det') {
1437 if (method_exists($element,
'fetch_thirdparty')) {
1438 $element->fetch_thirdparty();
1442 $expensereport->fetch($element->fk_expensereport);
1447 if ($breakline && $saved_third_id != $element->thirdparty->id) {
1450 $saved_third_id = $element->thirdparty->id;
1453 $total_ht_by_third = 0;
1454 $total_ttc_by_third = 0;
1457 $saved_third_id = empty($element->thirdparty->id) ? 0 : $element->thirdparty->id;
1459 $qualifiedfortotal =
true;
1460 if ($key ==
'invoice') {
1461 if (!empty($element->close_code) && $element->close_code ==
'replaced') {
1462 $qualifiedfortotal =
false;
1464 } elseif ($key ==
'order_supplier' && ($element->status == 6 || $element->status == 7)) {
1465 $qualifiedfortotal =
false;
1468 if ($key ==
"order_supplier" && ($element->status == 6 || $element->status == 7)) {
1469 print
'<tr class="oddeven tr_canceled">';
1470 } elseif ($key ==
"order_supplier" && ($element->billed)) {
1471 print
'<tr class="oddeven tr_paid">';
1473 print
'<tr class="oddeven" >';
1478 print
'<td style="width: 24px">';
1479 if ($tablename !=
'projet_task' && $tablename !=
'stock_mouvement') {
1481 print
'<a href="'.$_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'&action=unlink&tablename='.$tablename.
'&elementselect='.$element->id.($project_field ?
'&projectfield='.$project_field :
'').
'" class="reposition">';
1482 print
img_picto($langs->trans(
'Unlink'),
'unlink');
1489 print
'<td class="left nowraponall">';
1490 if ($tablename ==
'expensereport_det') {
1491 print $expensereport->getNomUrl(1);
1493 print
'<table><tr><td style="border-bottom: none;">';
1495 if ($element instanceof
Task) {
1496 print $element->getNomUrl(1,
'withproject',
'time');
1497 print
' - '.dol_trunc($element->label, 48);
1498 } elseif ($key ==
'loan') {
1499 print $element->getNomUrl(1);
1500 print
' - '.dol_trunc($element->label, 48);
1502 print $element->getNomUrl(1);
1505 $element_doc = $element->element;
1507 if (!empty($conf->$element_doc)) {
1508 $confelementdoc = $conf->$element_doc;
1509 $filedir = $confelementdoc->multidir_output[$element->entity ?? $conf->entity].
'/'.
dol_sanitizeFileName($element->ref);
1514 if ($element_doc ===
'order_supplier') {
1515 $element_doc =
'commande_fournisseur';
1516 $filedir = $conf->fournisseur->commande->multidir_output[$element->entity ?? $conf->entity].
'/'.
dol_sanitizeFileName($element->ref);
1517 } elseif ($element_doc ===
'invoice_supplier') {
1518 $element_doc =
'facture_fournisseur';
1519 $filename =
get_exdir($element->id, 2, 0, 0, $element,
'invoice_supplier').dol_sanitizeFileName($element->ref);
1520 $filedir = $conf->fournisseur->facture->multidir_output[$element->entity ?? $conf->entity].
'/'.$filename;
1523 print
'<div class="inline-block valignmiddle">';
1525 print $formfile->getDocumentsLink($element_doc, $filename, $filedir);
1531 print
'<td class="tdoverflowmax250" style="border-bottom: none;">';
1534 if (!empty($element->ref_supplier)) {
1535 print
' - '.$element->ref_supplier;
1538 if (!empty($element->ref_customer)) {
1539 print
' - '.$element->ref_customer;
1542 if (empty($element->ref_customer) && !empty($element->ref_client)) {
1543 print
' - '.$element->ref_client;
1546 print
'</td></tr></table>';
1550 if (
'MouvementStock' == $classname) {
1551 '@phan-var-force MouvementStock $element';
1552 $mvsProd =
new Product($element->db);
1553 $mvsProd->fetch($element->product_id);
1554 print
'<td>'.$mvsProd->getNomUrl(1).
'</td>';
1555 print
'<td>'.$element->qty.
'</td>';
1559 $total_time_by_line = 0;
1560 if ($tablename ==
'expensereport_det') {
1561 '@phan-var-force ExpenseReportLine $element';
1562 $date = $element->date;
1563 } elseif ($tablename ==
'stock_mouvement') {
1564 '@phan-var-force MouvementStock $element';
1565 $date = $element->datem;
1566 } elseif ($tablename ==
'salary') {
1567 '@phan-var-force Salary $element';
1568 $date = $element->datesp;
1569 } elseif ($tablename ==
'payment_various') {
1570 '@phan-var-force PaymentVarious $element';
1571 $date = $element->datev;
1572 } elseif ($tablename ==
'chargesociales') {
1573 '@phan-var-force ChargeSociales $element';
1574 $date = $element->date_ech;
1575 } elseif (!empty($element->status) || !empty($element->statut) || !empty($element->fk_status)) {
1576 if ($tablename ==
'don') {
1577 '@phan-var-force Don $element';
1578 $date = $element->date;
1580 if ($tablename ==
'commande_fournisseur' || $tablename ==
'supplier_order') {
1581 '@phan-var-force CommandeFournisseur $element';
1582 $date = ($element->date_commande ? $element->date_commande : $element->date_valid);
1583 } elseif ($tablename ==
'supplier_proposal') {
1584 '@phan-var-force SupplierProposal $element';
1585 $date = $element->date_validation;
1586 } elseif ($tablename ==
'fichinter') {
1587 '@phan-var-force Fichinter $element';
1588 $date = $element->datev;
1589 } elseif ($tablename ==
'projet_task') {
1590 '@phan-var-force Task $element';
1593 $date = $element->date;
1595 $date = $element->date_contrat;
1598 $date = $element->datev;
1600 if (empty($date) && !empty($datefieldname)) {
1602 $date = $element->$datefieldname;
1605 } elseif ($key ==
'loan') {
1606 '@phan-var-force Loan $element';
1607 $date = $element->datestart;
1610 print
'<td class="center">';
1611 if ($tablename ==
'actioncomm') {
1612 '@phan-var-force ActionComm $element';
1614 if ($element->datef && $element->datef > $element->datep) {
1615 print
" - ".dol_print_date($element->datef,
'dayhour');
1617 } elseif (in_array($tablename, array(
'projet_task'))) {
1618 '@phan-var-force Task $element';
1619 $tmpprojtime = $element->getSumOfAmount($idofelementuser ? $elementuser :
'', (string) $dates, (string) $datee);
1620 print
'<a href="'.DOL_URL_ROOT.
'/projet/tasks/time.php?id='.$idofelement.
'&withproject=1">';
1623 $total_time_by_line = $tmpprojtime[
'nbseconds'];
1630 print
'<td class="tdoverflowmax150">';
1631 if (is_object($element->thirdparty)) {
1632 print $element->thirdparty->getNomUrl(1,
'', 48);
1633 } elseif ($tablename ==
'expensereport_det') {
1634 $tmpuser =
new User($db);
1635 $tmpuser->fetch($expensereport->fk_user_author);
1636 print $tmpuser->getNomUrl(1,
'', 48);
1637 } elseif ($tablename ==
'salary') {
1638 $tmpuser =
new User($db);
1639 $tmpuser->fetch($element->fk_user);
1640 print $tmpuser->getNomUrl(1,
'', 48);
1641 } elseif ($tablename ==
'don' || $tablename ==
'stock_mouvement') {
1642 '@phan-var-force Don|MouvementStock $element';
1643 if ($element->fk_user_author > 0) {
1644 $tmpuser2 =
new User($db);
1645 $tmpuser2->fetch($element->fk_user_author);
1646 print $tmpuser2->getNomUrl(1,
'', 48);
1648 } elseif ($tablename ==
'projet_task' && $key ==
'element_time') {
1649 print $elementuser->getNomUrl(1);
1650 } elseif ($tablename ==
'payment_various') {
1651 '@phan-var-force PaymentVarious $element';
1652 print $element->label;
1657 if ($tablename ==
'fichinter') {
1658 '@phan-var-force FichInter $element';
1660 print
convertSecondToTime($element->duration,
'all', $conf->global->MAIN_DURATION_OF_WORKDAY);
1661 $total_duration += $element->duration;
1666 if ($tablename ==
'expensereport_det') {
1667 print
'<td class="left linecoltype">';
1668 $labeltype = ($langs->trans(($element->type_fees_code)) == $element->type_fees_code ? $element->type_fees_libelle : $langs->trans($element->type_fees_code));
1669 print (
string) $labeltype;
1673 if ($tablename ==
'expensereport_det') {
1674 print
'<td class="left linecolcomment">';
1675 print (
string) $element->comments;
1682 if (empty($value[
'disableamount'])) {
1683 $total_ht_by_line =
null;
1685 if ($tablename ==
'don' || $tablename ==
'chargesociales' || $tablename ==
'payment_various' || $tablename ==
'salary') {
1686 '@phan-var-force Don|ChargeSociales|PaymentVarious|Salary $element';
1687 $total_ht_by_line = $element->amount;
1688 } elseif ($tablename ==
'fichinter') {
1689 '@phan-var-force FichInter $element';
1690 $total_ht_by_line = $element->getAmount();
1691 } elseif ($tablename ==
'stock_mouvement') {
1692 '@phan-var-force MouvementStock $element';
1693 $total_ht_by_line = $element->price * abs($element->qty);
1694 } elseif (in_array($tablename, array(
'projet_task'))) {
1697 $total_ht_by_line =
price2num($tmpprojtime[
'amount'],
'MT');
1698 if (isset($tmpprojtime[
'nblinesnull']) && ($tmpprojtime[
'nblinesnull'] > 0)) {
1699 $langs->load(
"errors");
1700 $warning = $langs->trans(
"WarningSomeLinesWithNullHourlyRate", $conf->currency);
1703 $othermessage = $form->textwithpicto($langs->trans(
"NotAvailable"), $langs->trans(
"ModuleSalaryToDefineHourlyRateMustBeEnabled"));
1705 } elseif ($key ==
'loan') {
1706 '@phan-var-force Loan $element';
1707 $total_ht_by_line = $element->capital;
1709 $total_ht_by_line = $element->total_ht;
1713 if ($tablename ==
'payment_various') {
1714 if ($element->sens == 0) {
1715 $total_ht_by_line = -$total_ht_by_line;
1719 print
'<td class="right">';
1720 if ($othermessage) {
1721 print
'<span class="opacitymedium">'.$othermessage.
'</span>';
1723 if (isset($total_ht_by_line)) {
1724 if (!$qualifiedfortotal) {
1727 print
'<span class="amount">'.price($total_ht_by_line).
'</span>';
1728 if (!$qualifiedfortotal) {
1733 print
' '.img_warning($warning);
1735 if (isset($tmpprojtime[
'nblinesnull']) && ($tmpprojtime[
'nblinesnull'] > 0)) {
1736 if ($tmpprojtime[
'nbuserthmnull'] > 0) {
1737 $title = $langs->trans(
"EnterUsersHourlyRateFirst");
1738 print
' '.img_picto($title,
"sync",
'', 0, 0, 0,
'',
'opacitymedium');
1740 $title = $langs->trans(
"UpdateUndefinedWithLastHourlyRate");
1741 print
' <a class="reposition" href="'.$_SERVER[
"PHP_SELF"].
'?id='.
$id.
'&action=updateundefinedwithlasthourlyrate&taskid='.$idofelement.
'&token='.
currentToken().
'">'.
img_picto($title,
"sync",
'', 0, 0, 0,
'',
'warning').
'</a>';
1744 if (
getDolGlobalString(
'PROJECT_CAN_OVERWRITE_TIMESTPENT_HOURLY_RATE_WITH_LASTONE')) {
1745 $title = $langs->trans(
"UpdateWithLastHourlyRate");
1746 print
' <a class="reposition" href="'.$_SERVER[
"PHP_SELF"].
'?id='.
$id.
'&action=updateallwithlasthourlyrate&taskid='.$idofelement.
'&token='.
currentToken().
'">'.
img_picto($title,
"sync",
'', 0, 0, 0,
'',
'').
'</a>';
1754 if (empty($value[
'disableamount'])) {
1755 $total_ttc_by_line =
null;
1756 if ($tablename ==
'don' || $tablename ==
'chargesociales' || $tablename ==
'payment_various' || $tablename ==
'salary') {
1757 '@phan-var-force Don|ChargeSociales|PaymentVarious $element';
1758 $total_ttc_by_line = $element->amount;
1759 } elseif ($tablename ==
'fichinter') {
1760 '@phan-var-force Fichinter $element';
1761 $total_ttc_by_line = $element->getAmount();
1762 } elseif ($tablename ==
'stock_mouvement') {
1763 '@phan-var-force MouvementStock $element';
1764 $total_ttc_by_line = $element->price * abs($element->qty);
1765 } elseif ($tablename ==
'projet_task') {
1769 $total_ttc_by_line =
price2num($total_ht_by_line * (1 + ($defaultvat / 100)),
'MT');
1771 $othermessage = $form->textwithpicto($langs->trans(
"NotAvailable"), $langs->trans(
"ModuleSalaryToDefineHourlyRateMustBeEnabled"));
1773 } elseif ($key ==
'loan') {
1774 '@phan-var-force Loan $element';
1775 $total_ttc_by_line = $element->capital - $element->getSumPayment();
1777 $total_ttc_by_line = $element->total_ttc;
1781 if ($tablename ==
'payment_various') {
1782 if ($element->sens == 0) {
1783 $total_ttc_by_line = -$total_ttc_by_line;
1787 print
'<td class="right">';
1788 if ($othermessage) {
1789 print $othermessage;
1791 if (isset($total_ttc_by_line)) {
1792 if (!$qualifiedfortotal) {
1795 print
'<span class="amount">'.price($total_ttc_by_line).
'</span>';
1796 if (!$qualifiedfortotal) {
1801 print
' '.img_warning($warning);
1803 if (isset($tmpprojtime[
'nblinesnull']) && ($tmpprojtime[
'nblinesnull'] > 0)) {
1804 if ($tmpprojtime[
'nbuserthmnull'] > 0) {
1805 $title = $langs->trans(
"EnterUsersHourlyRateFirst");
1806 print
' '.img_picto($title,
"sync",
'', 0, 0, 0,
'',
'opacitymedium');
1808 $title = $langs->trans(
"UpdateUndefinedWithLastHourlyRate");
1809 print
' <a class="reposition" href="'.$_SERVER[
"PHP_SELF"].
'?id='.
$id.
'&action=updateundefinedwithlasthourlyrate&taskid='.$idofelement.
'&token='.
currentToken().
'">'.
img_picto($title,
"sync",
'', 0, 0, 0,
'',
'warning').
'</a>';
1812 if (
getDolGlobalString(
'PROJECT_CAN_OVERWRITE_TIMESTPENT_HOURLY_RATE_WITH_LASTONE')) {
1813 $title = $langs->trans(
"UpdateWithLastHourlyRate");
1814 print
' <a class="reposition" href="'.$_SERVER[
"PHP_SELF"].
'?id='.
$id.
'&action=updateallwithlasthourlyrate&taskid='.$idofelement.
'&token='.
currentToken().
'">'.
img_picto($title,
"sync").
'</a>';
1822 print
'<td class="right">';
1823 if ($tablename ==
'expensereport_det') {
1824 print $expensereport->getLibStatut(5);
1827 print $element->getLibStatut(5, $element->getSommePaiement());
1828 } elseif ($element instanceof
Task) {
1829 if ($element->progress !=
'') {
1830 print $element->progress.
' %';
1832 } elseif ($tablename ==
'stock_mouvement') {
1833 '@phan-var-force MouvementStock $element';
1834 print $element->getLibStatut(3);
1836 print $element->getLibStatut(5);
1842 if ($qualifiedfortotal) {
1843 $total_ht += $total_ht_by_line;
1844 $total_ttc += $total_ttc_by_line;
1846 $total_ht_by_third += $total_ht_by_line;
1847 $total_ttc_by_third += $total_ttc_by_line;
1849 if (!isset($total_time)) {
1850 $total_time = $total_time_by_line;
1852 $total_time += $total_time_by_line;
1857 $breakline =
'<tr class="liste_total liste_sub_total">';
1858 $breakline .=
'<td colspan="2">';
1859 $breakline .=
'</td>';
1860 $breakline .=
'<td>';
1861 $breakline .=
'</td>';
1862 $breakline .=
'<td class="right">';
1863 $breakline .= $langs->trans(
'SubTotal').
' : ';
1864 if (is_object($element->thirdparty)) {
1865 $breakline .= $element->thirdparty->getNomUrl(0,
'', 48);
1867 $breakline .=
'</td>';
1868 $breakline .=
'<td class="right">'.price($total_ht_by_third).
'</td>';
1869 $breakline .=
'<td class="right">'.price($total_ttc_by_third).
'</td>';
1870 $breakline .=
'<td></td>';
1871 $breakline .=
'</tr>';
1882 if (empty($nototal)) {
1884 if (in_array($tablename, array(
'projet_task'))) {
1888 print
'<tr class="liste_total"><td colspan="'.$colspan.
'">'.$langs->trans(
"Number").
': '.$i.
'</td>';
1889 if (in_array($tablename, array(
'projet_task'))) {
1890 print
'<td class="center">';
1899 if ($tablename ==
'fichinter') {
1900 print
'<td class="left">'.convertSecondToTime($total_duration,
'all', $conf->global->MAIN_DURATION_OF_WORKDAY).
'</td>';
1902 print
'<td class="right">';
1903 if (empty($value[
'disableamount'])) {
1904 if ($key ==
'loan') {
1905 print $langs->trans(
"Total").
' '.$langs->trans(
"LoanCapital").
' : '.
price($total_ttc);
1906 } elseif ($tablename !=
'projet_task' ||
isModEnabled(
'salaries')) {
1907 print
''.$langs->trans(
"TotalHT").
' : '.
price($total_ht);
1913 print
'<td class="right">';
1914 if (empty($value[
'disableamount'])) {
1915 if ($key ==
'loan') {
1916 print $langs->trans(
"Total").
' '.$langs->trans(
"RemainderToPay").
' : '.
price($total_ttc);
1917 } elseif ($tablename !=
'projet_task' ||
isModEnabled(
'salaries')) {
1918 print $langs->trans(
"TotalTTC").
' : '.
price($total_ttc);
1922 print
'<td> </td>';
1924 if ($tablename ==
'expensereport_det') {
1925 print
'<td> </td>';
1926 print
'<td> </td>';
1931 if (!is_array($elementarray)) {
1932 print
'<tr><td>'.$elementarray.
'</td></tr>';
1935 if ($tablename ==
'fichinter') {
1938 print
'<tr><td colspan="'.$colspan.
'"><span class="opacitymedium">'.$langs->trans(
"None").
'</td></tr>';
1948if ($conf->use_javascript_ajax) {
1949 include_once DOL_DOCUMENT_ROOT.
'/core/lib/ajax.lib.php';
1952 print $comboenhancement;
1974 return in_array($tablename, array(
'facture_fourn',
'commande_fournisseur'));
1985 global $db, $classname;
1986 '@phan-var-force string $classname';
1988 $element =
new $classname($db);
1989 '@phan-var-force CommonObject $element';
1991 $clientname = array();
1992 foreach ($elementarray as $key =>
$id) {
1993 if (empty($clientname[
$id])) {
1994 $element->fetch(
$id);
1995 $element->fetch_thirdparty();
1997 $clientname[
$id] = $element->thirdparty->name;
2004 $elementarray = array();
2005 foreach ($clientname as
$id => $name) {
2006 $elementarray[] =
$id;
2009 return $elementarray;
$id
Support class for third parties, contacts, members, users or resources.
if(! $sortfield) if(! $sortorder) $object
ajax_combobox($htmlname, $events=array(), $minLengthToAutocomplete=0, $forcefocus=0, $widthTypeOfAutocomplete='resolve', $idforemptyvalue='-1', $morecss='')
Convert a html select field into an ajax combobox.
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader($head='', $title='', $help_url='', $target='', $disablejs=0, $disablehead=0, $arrayofjs='', $arrayofcss='', $morequerystring='', $morecssonbody='', $replacemainareaby='', $disablenofollow=0, $disablenoindex=0)
Empty header.
Superclass for invoice classes.
Class for ConferenceOrBoothAttendee.
Class to manage Trips and Expenses.
const TYPE_DEPOSIT
Deposit invoice.
Class to manage Schedule of loans.
Class to manage products or services.
Class to manage projects.
const STATUS_SIGNED
Signed quote.
const STATUS_BILLED
Billed or processed quote.
Class to manage Dolibarr users.
dol_get_first_day($year, $month=1, $gm=false)
Return GMT time for first day of a month or year.
convertSecondToTime($iSecond, $format='all', $lengthOfDay=86400, $lengthOfWeek=7)
Return, in clear text, value of a number of seconds in days, hours and minutes.
dol_stringtotime($string, $gm=1)
Convert a string date into a GM Timestamps date Warning: YYYY-MM-DDTHH:MM:SS+02:00 (RFC3339) is not s...
sortElementsByClientName($elementarray)
sortElementsByClientName
canApplySubtotalOn($tablename)
Return if we should do a group by customer with sub-total.
dol_now($mode='gmt')
Return date for now.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed information (by default a local PHP server timestamp) Rep...
dol_getIdFromCode($db, $key, $tablename, $fieldkey='code', $fieldid='id', $entityfilter=0, $filters='', $useCache=true)
Return an id or code from a code or id.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
Show picto whatever it's its name (generic function)
img_warning($titlealt='default', $moreatt='', $morecss='pictowarning')
Show warning logo.
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0, $morecssdiv='')
Show tabs of a record.
dolPrintHTML($s, $allowiframe=0)
Return a string (that can be on several lines) ready to be output on a HTML page.
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
currentToken()
Return the value of token currently saved into session with name 'token'.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
dol_eval($s, $returnvalue=1, $hideerrors=1, $onlysimplestring='1')
Replace eval function to add more security.
setEventMessage($mesgs, $style='mesgs', $noduplicate=0, $attop=0)
Set event message in dol_events session object.
dol_sanitizeFileName($str, $newstr='_', $unaccent=1, $includequotes=0, $allowdash=0)
Clean a string to use it as a file name.
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.
dol_escape_js($stringtoescape, $mode=0, $noescapebackslashn=0)
Returns text escaped for inclusion into javascript code.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_clone($srcobject, $native=2)
Create a clone of instance of object (new instance with same value for each properties) With native =...
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false, $decorate=0)
Output date in a string format according to outputlangs (or langs if not defined).
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='', $morecssonpicto='widthpictotitle')
Load a title with picto.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
isModEnabled($module)
Is Dolibarr module enabled.
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_exdir($num, $level, $alpha, $withoutslash, $object, $modulepart='')
Return a path to have a the directory according to object where files are stored.
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...
project_prepare_head(Project $project, $moreparam='')
Prepare array with list of tabs.
restrictedArea(User $user, $features, $object=0, $tableandshare='', $feature2='', $dbt_keyfield='fk_soc', $dbt_select='rowid', $isdraft=0, $mode=0)
Check permissions of a user to show a page and an object.