36require
'../main.inc.php';
37require_once DOL_DOCUMENT_ROOT.
'/fichinter/class/fichinter.class.php';
38require_once DOL_DOCUMENT_ROOT.
'/fichinter/class/fichinterrec.class.php';
39require_once DOL_DOCUMENT_ROOT.
'/core/lib/fichinter.lib.php';
41require_once DOL_DOCUMENT_ROOT.
'/product/class/product.class.php';
42require_once DOL_DOCUMENT_ROOT.
'/core/lib/date.lib.php';
44 require_once DOL_DOCUMENT_ROOT.
'/projet/class/project.class.php';
45 require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formprojet.class.php';
48 require_once DOL_DOCUMENT_ROOT.
'/contrat/class/contrat.class.php';
49 require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formcontract.class.php';
61$langs->loadLangs(array(
"interventions",
"admin",
"compta",
"bills"));
66$date_next_execution =
GETPOST(
'date_next_execution',
'alpha');
67$action =
GETPOST(
'action',
'aZ09');
69$backtopage =
GETPOST(
'backtopage',
'alpha');
72 $socid = $user->socid;
74$objecttype =
'fichinter_rec';
75if ($action ==
"create" || $action ==
"add") {
81$sortfield =
GETPOST(
'sortfield',
'aZ09comma');
82$sortorder =
GETPOST(
'sortorder',
'aZ09comma');
84if (empty($page) || $page < 0 ||
GETPOST(
'button_search',
'alpha') ||
GETPOST(
'button_removefilter',
'alpha')) {
88$offset = $limit * $page;
93$sortorder =
GETPOST(
'sortorder',
'aZ09comma');
94$sortfield =
GETPOST(
'sortfield',
'aZ09comma');
95if ($sortorder ==
"") {
99if ($sortfield ==
"") {
100 $sortfield =
"f.datec";
107 'f.title' => array(
'label' =>
"Ref",
'checked' => 1),
108 's.nom' => array(
'label' =>
"ThirdParty",
'checked' => 1),
109 'f.fk_contrat' => array(
'label' =>
"Contract",
'checked' => 1),
110 'f.duree' => array(
'label' =>
"Duration",
'checked' => 1),
111 'f.total_ttc' => array(
'label' =>
"AmountTTC",
'checked' => 1),
112 'f.frequency' => array(
'label' =>
"RecurringInvoiceTemplate",
'checked' => 1),
113 'f.nb_gen_done' => array(
'label' =>
"NbOfGenerationDoneShort",
'checked' => 1),
114 'f.date_last_gen' => array(
'label' =>
"DateLastGeneration",
'checked' => 1),
115 'f.date_when' => array(
'label' =>
"NextDateToExecution",
'checked' => 1),
116 'f.datec' => array(
'label' =>
"DateCreation",
'checked' => 0,
'position' => 500),
117 'f.tms' => array(
'label' =>
"DateModificationShort",
'checked' => 0,
'position' => 500),
122$permissiontoadd = $user->hasRight(
'ficheinter',
'creer');
123$permissiontodelete = $user->hasRight(
'ficheinter',
'supprimer');
132 if (!empty($backtopageforcancel)) {
133 header(
"Location: ".$backtopageforcancel);
135 } elseif (!empty($backtopage)) {
136 header(
"Location: ".$backtopage);
143if ($action ==
'add' && $permissiontoadd) {
145 setEventMessages($langs->transnoentities(
"ErrorFieldRequired", $langs->trans(
"Title")),
null,
'errors');
151 setEventMessages($langs->transnoentities(
"ErrorFieldRequired", $langs->trans(
"Customer")),
null,
'errors');
158 $rec_year =
GETPOST(
'rec_year');
159 $rec_month =
GETPOST(
'rec_month');
161 $rec_hour =
GETPOST(
'rec_hour');
165 if (empty($rec_year) || empty($rec_month) || empty($rec_day)) {
166 setEventMessages($langs->transnoentities(
"ErrorFieldRequired", $langs->trans(
"Date")),
null,
'errors');
170 $date_next_execution =
dol_mktime((
int) $rec_hour, (
int) $rec_min, 0, (
int) $rec_month, (
int) $rec_day, (
int) $rec_year);
172 if ($nb_gen_max === 0) {
173 setEventMessages($langs->transnoentities(
"ErrorFieldRequired", $langs->trans(
"MaxPeriodNumber")),
null,
'errors');
187 $object->frequency = $frequency;
189 $object->nb_gen_max = $nb_gen_max;
192 $object->date_when = $date_next_execution;
194 if (
$object->create($user) > 0) {
202} elseif ($action ==
'createfrommodel' && $permissiontoadd) {
210 $newinter->socid =
$object->socid;
211 $newinter->fk_project =
$object->fk_project;
212 $newinter->fk_contrat =
$object->fk_contrat;
217 $newinter->entity =
$object->entity;
218 $newinter->duration =
$object->duration;
220 $newinter->description =
$object->description;
221 $newinter->note_private =
$object->note_private;
222 $newinter->note_public =
$object->note_public;
225 $extrafields->fetch_name_optionals_label($newinter->table_element);
227 $array_options = $extrafields->getOptionalsFromPost($newinter->table_element);
228 $newinter->array_options = $array_options;
230 $newfichinterid = $newinter->create($user);
232 if ($newfichinterid > 0) {
234 foreach (
$object->lines as $line) {
235 $newinter->addline($user, $newfichinterid, $line->desc, $line->datei, $line->duree, array());
241 header(
'Location: '.DOL_URL_ROOT.
'/fichinter/card.php?id='.$newfichinterid);
247} elseif ($action ==
'delete' && $permissiontodelete) {
252 header(
'Location: '.$_SERVER[
"PHP_SELF"]);
254} elseif ($action ==
'setfrequency' && $permissiontoadd) {
258} elseif ($action ==
'setdate_when' && $permissiontoadd) {
265} elseif ($action ==
'setnb_gen_max' && $permissiontoadd) {
278llxHeader(
'', $langs->trans(
"RepeatableIntervention"), $help_url,
'', 0, 0,
'',
'',
'',
'mod-fichinter page-card-rec');
280$form =
new Form($db);
282$companystatic =
new Societe($db);
283$contratstatic =
null;
284$projectstatic =
null;
286 $contratstatic =
new Contrat($db);
289 $projectstatic =
new Project($db);
294$today =
dol_mktime(23, 59, 59, $tmparray[
'mon'], $tmparray[
'mday'], $tmparray[
'year']);
300if ($action ==
'create') {
301 print
load_fiche_titre($langs->trans(
"CreateRepeatableIntervention"),
'',
'intervention');
306 if (
$object->fetch($id, $ref) > 0) {
307 print
'<form action="card-rec.php" method="post">';
308 print
'<input type="hidden" name="token" value="'.newToken().
'">';
309 print
'<input type="hidden" name="action" value="add">';
310 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
311 print
'<input type="hidden" name="fichinterid" value="'.$object->id.
'">';
323 print
'<table class="border centpercent">';
328 print
'<tr><td>'.$langs->trans(
"Customer").
'</td><td>';
329 print $form->select_company(
$object->thirdparty->id,
'socid',
'', 0, 1);
333 print $langs->trans(
"Comment");
337 print
'<tr><td class="fieldrequired">'.$langs->trans(
"Title").
'</td><td>';
338 print
'<input class="flat quatrevingtpercent" type="text" name="title" value="'.dol_escape_htmltag(
GETPOST(
"title",
"alphanohtml")).
'">';
342 print
'<td rowspan="'.$rowspan.
'" valign="top">';
343 print
'<textarea class="flat" name="description" wrap="soft" cols="60" rows="'.ROWS_4.
'">';
344 print
$object->description.
'</textarea>';
348 print
"<tr><td>".$langs->trans(
"Author").
"</td><td>".$user->getFullName($langs).
"</td></tr>";
352 print
'<tr><td>'.$langs->trans(
"TotalDuration").
'</td>';
353 print
'<td colspan="3">'.convertSecondToTime(
$object->duration,
'all', $conf->global->MAIN_DURATION_OF_WORKDAY).
'</td>';
360 print
"<tr><td>".$langs->trans(
"Project").
"</td><td>";
363 $numprojet = $formproject->select_projects(
$object->thirdparty->id, $projectid,
'projectid', 0, 0, 1, 0, 0, 0, 0,
'', 0, 0,
'');
364 print
' <a href="'.DOL_URL_ROOT.
'/projet/card.php?socid='.
$object->thirdparty->id;
365 print
'&action=create&status=1&backtopage='.urlencode($_SERVER[
"PHP_SELF"]).
'?action=create';
366 print
'&socid='.$object->thirdparty->id.(!empty($id) ?
'&id='.$id :
'').
'">';
367 print $langs->trans(
"AddProject").
'</a>';
374 print
"<tr><td>".$langs->trans(
"Contract").
"</td><td>";
376 $numcontract = $formcontract->select_contract(
$object->thirdparty->id, $contractid,
'contracttid');
385 $title = $langs->trans(
"Recurrence");
388 print
'<table class="border centpercent">';
391 print
'<tr><td class="titlefieldcreate">';
392 print $form->textwithpicto($langs->trans(
"Frequency"), $langs->transnoentitiesnoconv(
'toolTipFrequency'));
394 print
'<input type="text" name="frequency" value="'.GETPOSTINT(
'frequency').
'" size="4"> ';
395 print $form->selectarray(
'unit_frequency', array(
'd' => $langs->trans(
'Day'),
'm' => $langs->trans(
'Month'),
'y' => $langs->trans(
'Year')), (
GETPOST(
'unit_frequency') ?
GETPOST(
'unit_frequency') :
'm'));
399 print
"<tr><td>".$langs->trans(
'NextDateToExecution').
"</td><td>";
400 if (empty($date_next_execution)) {
403 print $form->selectDate($date_next_execution,
'rec_', 1, 1, 0,
"add", 1, 1);
407 print
"<tr><td>".$langs->trans(
"MaxPeriodNumber").
"</td><td>";
408 print
'<input type="text" name="nb_gen_max" value="'.GETPOSTINT(
'nb_gen_max').
'" size="5">';
415 $title = $langs->trans(
"ProductsAndServices");
417 $title = $langs->trans(
"Products");
419 $title = $langs->trans(
"Services");
427 print
'<table class="notopnoleftnoright" width="100%">';
428 print
'<tr><td colspan="3">';
430 $sql =
'SELECT l.rowid, l.description, l.duree';
431 $sql .=
" FROM ".MAIN_DB_PREFIX.
"fichinterdet as l";
432 $sql .=
" WHERE l.fk_fichinter= ".((int)
$object->id);
434 $sql .=
" ORDER BY l.rang";
436 $result = $db->query($sql);
438 $num = $db->num_rows($result);
442 echo
'<table class="noborder centpercent">';
444 print
'<tr class="liste_titre">';
445 print
'<td>'.$langs->trans(
"Description").
'</td>';
446 print
'<td class="center">'.$langs->trans(
"Duration").
'</td>';
450 $objp = $db->fetch_object($result);
451 print
'<tr class="oddeven">';
456 print
'<a name="'.$objp->rowid.
'"></a>';
458 $text =
img_object($langs->trans(
'Service'),
'service');
460 print $text.
' '.nl2br($objp->description);
463 print
'<td class="center">'.convertSecondToTime($objp->duree).
'</td>';
480 print $form->buttonsSaveCancel(
"Create");
486} elseif ($action ==
'selsocforcreatefrommodel') {
487 print
load_fiche_titre($langs->trans(
"CreateRepeatableIntervention"),
'',
'intervention');
490 print
'<form name="fichinter" action="'.$_SERVER[
'PHP_SELF'].
'" method="POST">';
491 print
'<table class="border centpercent">';
492 print
'<tr><td class="fieldrequired">'.$langs->trans(
"ThirdParty").
'</td><td>';
493 print $form->select_company(
'',
'socid',
'', 1, 1);
499 print
'<input type="hidden" name="action" value="createfrommodel">';
500 print
'<input type="hidden" name="id" value="'.$id.
'">';
501 print
'<input type="hidden" name="token" value="'.newToken().
'">';
502 print $form->buttonsSaveCancel(
"CreateDraftIntervention",
'');
512 $author =
new User($db);
513 $author->fetch((
int)
$object->user_author_id);
520 $linkback =
'<a href="card-rec.php">'.$langs->trans(
"BackToList").
'</a>';
522 $morehtmlref =
'<div class="refidno">';
525 $morehtmlref .= $langs->trans(
'ThirdParty').
' : '.
$object->thirdparty->getNomUrl(1);
529 $langs->load(
"projects");
530 $morehtmlref .=
'<br>'.$langs->trans(
'Project').
' ';
531 if ($user->hasRight(
'ficheinter',
'creer')) {
532 if ($action !=
'classify') {
533 $morehtmlref .=
'<a class="editfielda" href="'.dolBuildUrl($_SERVER[
'PHP_SELF'], [
'action' =>
'classify',
'id' =>
$object->id],
true).
'">';
534 $morehtmlref .=
img_edit($langs->transnoentitiesnoconv(
'SetProject')).
'</a> : ';
536 if ($action ==
'classify') {
537 $morehtmlref .=
'<form method="post" action="'.$_SERVER[
'PHP_SELF'].
'?id='.
$object->id.
'">';
538 $morehtmlref .=
'<input type="hidden" name="action" value="classin">';
539 $morehtmlref .=
'<input type="hidden" name="token" value="'.newToken().
'">';
540 $morehtmlref .= $formproject->select_projects(
$object->socid, (
string)
$object->fk_project,
'projectid', $maxlength, 0, 1, 0, 1, 0, 0,
'', 1);
541 $morehtmlref .=
'<input type="submit" class="button valignmiddle" value="'.$langs->trans(
"Modify").
'">';
542 $morehtmlref .=
'</form>';
544 $morehtmlref .= $form->form_project($_SERVER[
'PHP_SELF'].
'?id='.
$object->id,
$object->socid, (
string)
$object->fk_project,
'none', 0, 0, 0, 1,
'',
'maxwidth300');
547 if (!empty(
$object->fk_project)) {
549 $proj->fetch(
$object->fk_project);
550 $morehtmlref .=
' : '.$proj->getNomUrl(1);
552 $morehtmlref .=
' - '.$proj->title;
559 $morehtmlref .=
'</div>';
561 dol_banner_tab($object,
'ref', $linkback, 1,
'ref',
'ref', $morehtmlref);
563 print
'<div class="fichecenter">';
564 print
'<div class="fichehalfleft">';
565 print
'<div class="underbanner clearboth"></div>';
567 print
'<table class="border centpercent">';
569 print
"<tr><td>".$langs->trans(
"Author").
'</td><td colspan="3">'.$author->getFullName($langs).
"</td></tr>";
573 print
'<tr><td class="titlefield">'.$langs->trans(
"TotalDuration").
'</td>';
574 print
'<td colspan="3">';
579 print
'<tr><td>'.$langs->trans(
"Description").
'</td><td colspan="3">'.nl2br(
$object->description).
"</td></tr>";
582 if (
isModEnabled(
'contract') && $contratstatic !==
null) {
583 $langs->load(
'contracts');
587 print
'<table class="nobordernopadding" width="100%"><tr><td>';
588 print $langs->trans(
'Contract');
590 if ($action !=
'contrat') {
591 print
'<td class="right"><a href="'.$_SERVER[
"PHP_SELF"].
'?action=contrat&id='.
$object->id.
'&token='.
newToken().
'">';
592 print
img_edit($langs->trans(
'SetContract'), 1);
595 print
'</tr></table>';
597 if ($action ==
'contrat') {
599 $formcontract->formSelectContract($_SERVER[
"PHP_SELF"].
'?id='.
$object->id,
$object->socid,
$object->fk_contrat,
'contratid', 0, 1);
602 $contratstatic =
new Contrat($db);
603 $contratstatic->fetch(
$object->fk_contrat);
604 print $contratstatic->getNomUrl(0, 0, 1);
615 print
'<div class="fichehalfright">';
616 print
'<div class="underbanner clearboth"></div>';
618 $title = $langs->trans(
"Recurrence");
621 print
'<table class="border centpercent">';
624 print
'<tr><td class="titlefield">';
625 print
'<table class="nobordernopadding" width="100%"><tr><td>';
626 print $langs->trans(
'Frequency');
628 if ($action !=
'editfrequency' && $user->hasRight(
'ficheinter',
'creer')) {
629 print
'<td class="right"><a href="'.$_SERVER[
"PHP_SELF"].
'?action=editfrequency&token='.
newToken().
'&id='.
$id.
'">';
630 print
img_edit($langs->trans(
'Edit'), 1).
'</a></td>';
632 print
'</tr></table>';
634 if ($action ==
'editfrequency') {
635 print
'<form method="post" action="'.$_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'">';
636 print
'<input type="hidden" name="action" value="setfrequency">';
637 print
'<input type="hidden" name="token" value="'.newToken().
'">';
638 print
'<table class="nobordernopadding">';
640 print
'<input type="text" name="frequency" value="'.$object->frequency.
'" size="5"> ';
641 print $form->selectarray(
'unit_frequency', array(
'd' => $langs->trans(
'Day'),
'm' => $langs->trans(
'Month'),
'y' => $langs->trans(
'Year')), (
$object->unit_frequency ?
$object->unit_frequency :
'm'));
643 print
'<td class="left"><input type="submit" class="button button-edit" value="'.$langs->trans(
"Modify").
'"></td>';
644 print
'</tr></table></form>';
647 print $langs->trans(
'FrequencyPer_'.
$object->unit_frequency,
$object->frequency);
649 print $langs->trans(
"NotARecurringInterventionalTemplate");
656 if ($user->hasRight(
'ficheinter',
'creer') && ($action ==
'date_when' ||
$object->frequency > 0)) {
657 print $form->editfieldkey($langs->trans(
"NextDateToExecution"),
'date_when',
$object->date_when, $object, $user->hasRight(
'ficheinter',
'creer'),
'day');
659 print $langs->trans(
"NextDateToExecution");
662 if ($action ==
'date_when' ||
$object->frequency > 0) {
663 print $form->editfieldval($langs->trans(
"NextDateToExecution"),
'date_when',
$object->date_when, $object, $user->hasRight(
'ficheinter',
'creer'),
'day');
670 if ($user->hasRight(
'ficheinter',
'creer') && ($action ==
'nb_gen_max' ||
$object->frequency > 0)) {
671 print $form->editfieldkey($langs->trans(
"MaxPeriodNumber"),
'nb_gen_max', (
string)
$object->nb_gen_max, $object, $user->hasRight(
'ficheinter',
'creer'));
673 print $langs->trans(
"MaxPeriodNumber");
677 if ($action ==
'nb_gen_max' ||
$object->frequency > 0) {
678 print $form->editfieldval($langs->trans(
"MaxPeriodNumber"),
'nb_gen_max',
$object->nb_gen_max ?
$object->nb_gen_max :
'',
$object, $user->hasRight(
'ficheinter',
'creer'));
692 $txtinfoadmin = $langs->trans(
"EnableAndSetupModuleCron", $langs->transnoentitiesnoconv(
"Module2300Name"));
695 print
'<div class="underbanner clearboth"></div>';
696 print
'<table class="border centpercent">';
699 print
'<tr><td class="titlefield">'.$langs->trans(
"NbOfGenerationOfRecordDone").
'</td>';
707 print $langs->trans(
"DateLastGeneration");
719 print
'<div class="clearboth"></div><br>';
725 $title = $langs->trans(
"ProductsAndServices");
727 $title = $langs->trans(
"Products");
729 $title = $langs->trans(
"Services");
734 print
'<table class="noborder centpercent">';
735 print
'<tr class="liste_titre">';
736 print
'<td>'.$langs->trans(
"Description").
'</td>';
737 print
'<td class="center">'.$langs->trans(
"Duration").
'</td>';
745 if (isset(
$object->lines[$i]->product_type)) {
746 $type =
$object->lines[$i]->product_type;
750 if (isset($objp) && is_object($objp)) {
752 if (!empty($objp->date_start)) {
755 if (!empty($objp->date_end)) {
761 print
'<tr class="oddeven">';
763 $text =
img_object($langs->trans(
'Service'),
'service');
764 print $text.
' '.nl2br(
$object->lines[$i]->desc);
767 print
'<td class="center">'.convertSecondToTime(
$object->lines[$i]->duree).
'</td>';
774 print
'<div class="tabsAction">';
776 if ($user->hasRight(
'ficheinter',
'creer')) {
777 print
'<div class="inline-block divButAction">';
778 print
'<a class="butAction" href="'.$_SERVER[
'PHP_SELF'].
'?action=createfrommodel&token='.
newToken();
779 print
'&socid='.$object->thirdparty->id.
'&id='.
$object->id.
'">';
780 print $langs->trans(
"AddIntervention").
'</a></div>';
784 print
dolGetButtonAction($langs->trans(
"Delete"),
'',
'delete', $_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'&action=delete&token='.
newToken(),
'delete', $user->hasRight(
'ficheinter',
'supprimer'));
788 print $langs->trans(
"ErrorRecordNotFound");
793 $sql =
"SELECT f.rowid as id, s.nom as name, s.rowid as socid, f.title,";
794 $sql .=
" f.duree, f.fk_contrat, f.fk_projet as fk_project, f.frequency, f.nb_gen_done, f.nb_gen_max,";
795 $sql .=
" f.date_last_gen, f.date_when, f.datec, f.status";
797 $sql .=
" FROM ".MAIN_DB_PREFIX.
"fichinter_rec as f";
798 $sql .=
" , ".MAIN_DB_PREFIX.
"societe as s ";
799 if (!$user->hasRight(
'societe',
'client',
'voir')) {
800 $sql .=
" , ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
802 $sql .=
" WHERE f.fk_soc = s.rowid";
803 $sql .=
" AND f.entity = ".$conf->entity;
804 if (!empty($socid)) {
805 $sql .=
" AND s.rowid = ".((int) $socid);
807 if (!$user->hasRight(
'societe',
'client',
'voir')) {
808 $sql .=
" AND s.rowid = sc.fk_soc AND sc.fk_user = ".((int) $user->id);
815 if (!empty($search_societe)) {
818 if (!empty($search_frequency) && $search_frequency ==
'1') {
819 $sql .=
' AND f.frequency > 0';
821 if (isset($search_frequency) && (
string) $search_frequency ==
'0') {
822 $sql .=
' AND (f.frequency IS NULL or f.frequency = 0)';
829 $resql = $db->query($sql);
831 $num = $db->num_rows($resql);
833 print_barre_liste($langs->trans(
"RepeatableIntervention"), $page, $_SERVER[
'PHP_SELF'],
"&socid=$socid", $sortfield, $sortorder,
'', $num,
'',
'intervention');
835 print
'<span class="opacitymedium">'.$langs->trans(
"ToCreateAPredefinedIntervention").
'</span><br><br>';
838 print
'<table class="noborder centpercent">';
839 print
'<tr class="liste_titre">';
840 print_liste_field_titre(
"Ref", $_SERVER[
'PHP_SELF'],
"f.title",
"",
"",
'width="200px"', $sortfield, $sortorder,
'left ');
841 print_liste_field_titre(
"Company", $_SERVER[
'PHP_SELF'],
"s.nom",
"",
"",
'width="200px"', $sortfield, $sortorder,
'left ');
843 print_liste_field_titre(
"Contract", $_SERVER[
'PHP_SELF'],
"f.fk_contrat",
"",
"",
'width="100px"', $sortfield, $sortorder,
'left ');
846 print_liste_field_titre(
"Project", $_SERVER[
'PHP_SELF'],
"f.fk_project",
"",
"",
'width="100px"', $sortfield, $sortorder,
'left ');
848 print_liste_field_titre(
"Duration", $_SERVER[
'PHP_SELF'],
'f.duree',
'',
'',
'width="50px"', $sortfield, $sortorder,
'right ');
850 print_liste_field_titre(
"Frequency", $_SERVER[
'PHP_SELF'],
"f.frequency",
"",
"",
'width="100px"', $sortfield, $sortorder,
'center ');
851 print_liste_field_titre(
"NbOfGenerationDoneShort", $_SERVER[
'PHP_SELF'],
"f.nb_gen_done",
"",
"",
'width="100px"', $sortfield, $sortorder,
'center ');
852 print_liste_field_titre(
"DateLastGeneration", $_SERVER[
'PHP_SELF'],
"f.date_last_gen",
"",
"",
'width="100px"', $sortfield, $sortorder,
'center ');
853 print_liste_field_titre(
"NextDateToIntervention", $_SERVER[
'PHP_SELF'],
"f.date_when",
"",
"",
'width="100px"', $sortfield, $sortorder,
'center ');
854 print
'<th width="100px"></th>';
861 while ($i < min($num, $limit)) {
862 $objp = $db->fetch_object($resql);
863 $fichinterrecstatic->id = $objp->id;
864 $fichinterrecstatic->ref = $objp->title;
865 $fichinterrecstatic->title = $objp->title;
867 print
'<tr class="oddeven">';
868 print
'<td>'.$fichinterrecstatic->getNomUrl(1).
"</td>\n";
870 $companystatic->id = $objp->socid;
871 $companystatic->name = $objp->name;
872 print
'<td>'.$companystatic->getNomUrl(1,
'customer').
'</td>';
874 print
'<td>'.$langs->trans(
"None").
'</td>';
877 if (
isModEnabled(
'contract') && $contratstatic !==
null) {
879 if ($objp->fk_contrat > 0) {
880 $contratstatic->fetch($objp->fk_contrat);
881 print $contratstatic->getNomUrl(1);
885 if (
isModEnabled(
'project') && $projectstatic !==
null) {
887 if ($objp->fk_project > 0) {
888 $projectstatic->fetch($objp->fk_project);
889 print $projectstatic->getNomUrl(1);
894 print
'<td class=right>'.convertSecondToTime($objp->duree).
'</td>';
896 print
'<td class="center">'.yn($objp->frequency ? 1 : 0).
'</td>';
898 print
'<td class="center">';
899 if ($objp->frequency) {
900 print $objp->nb_gen_done.($objp->nb_gen_max > 0 ?
' / '.$objp->nb_gen_max :
'');
903 print
'<td class="center">';
907 print
'<td class="center">';
911 print
'<span class="opacitymedium">'.$langs->trans(
'NA').
'</span>';
913 print
'<td class="center">';
914 print
'<span class="opacitymedium">'.$langs->trans(
'NA').
'</span>';
916 print
'<td class="center">';
917 print
'<span class="opacitymedium">'.$langs->trans(
'NA').
'</span>';
921 if ($user->hasRight(
'ficheinter',
'creer')) {
923 print
'<td class="center">';
924 if ($user->hasRight(
'ficheinter',
'creer')) {
925 if (empty($objp->frequency) || $db->jdate($objp->date_when) <= $today) {
926 print
'<a class="butAction" href="'.$_SERVER[
'PHP_SELF'].
'?action=createfrommodel';
927 print
'&socid='.$objp->socid.
'&id='.$objp->id.
'&token='.
newToken().
'">';
928 print $langs->trans(
"NewIntervention").
'</a>';
930 print $langs->trans(
"DateIsNotEnough");
943 print
'<tr class="oddeven"><td colspan="10"><span class="opacitymedium">'.$langs->trans(
"None").
'</span></td></tr>';
$id
Support class for third parties, contacts, members, users or resources.
if(! $sortfield) if(! $sortorder) $object
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.
Class to manage recurring interventions.
Class to manage projects.
Class to manage third parties objects (customers, suppliers, prospects...)
Class to manage Dolibarr users.
convertSecondToTime($iSecond, $format='all', $lengthOfDay=86400, $lengthOfWeek=7)
Return, in clear text, value of a number of seconds in days, hours and minutes.
fichinter_rec_prepare_head($object)
Prepare array with list of tabs.
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...
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
print_liste_field_titre($name, $file="", $field="", $begin="", $param="", $moreattrib="", $sortfield="", $sortorder="", $prefix="", $tooltip="", $forcenowrapcolumntitle=0)
Show title line of an array.
print_barre_liste($title, $page, $file, $options='', $sortfield='', $sortorder='', $morehtmlcenter='', $num=-1, $totalnboflines='', $picto='generic', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limit=-1, $selectlimitsuffix=0, $hidenavigation=0, $pagenavastextinput=0, $morehtmlrightbeforearrow='')
Print a title with navigation controls for pagination.
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.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $allowothertags=array())
Show a picto called object_picto (generic function)
natural_search($fields, $value, $mode=0, $nofirstand=0, $sqltoadd='')
Generate natural SQL search string for a criteria (this criteria can be tested on one or several fiel...
newToken()
Return the value of token currently saved into session with name 'newtoken'.
dolGetButtonAction($label, $text='', $actionType='default', $url='', $id='', $userRight=1, $params=array())
Function dolGetButtonAction.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
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.
info_admin($text, $infoonimgalt=0, $nodiv=0, $admin='1', $morecss='hideonsmartphone', $textfordropdown='', $picto='')
Show information in HTML for admin users or standard users.
img_edit($titlealt='default', $float=0, $other='')
Show logo edit/modify fiche.
dol_getdate($timestamp, $fast=false, $forcetimezone='')
Return an array with locale date info.
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.