29require
"../../main.inc.php";
30require_once DOL_DOCUMENT_ROOT.
'/projet/class/project.class.php';
31require_once DOL_DOCUMENT_ROOT.
'/projet/class/task.class.php';
32require_once DOL_DOCUMENT_ROOT.
'/core/lib/project.lib.php';
33require_once DOL_DOCUMENT_ROOT.
'/core/lib/date.lib.php';
34require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formother.class.php';
35require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formprojet.class.php';
36require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formcompany.class.php';
37require_once DOL_DOCUMENT_ROOT.
'/holiday/class/holiday.class.php';
40$langs->loadLangs(array(
'projects',
'users',
'companies'));
42$action =
GETPOST(
'action',
'aZ09');
43$mode =
GETPOST(
"mode",
'alpha');
47$contextpage =
GETPOST(
'contextpage',
'aZ') ?
GETPOST(
'contextpage',
'aZ') :
'timespent';
56$hookmanager->initHooks(array(
'timesheetpermonthcard'));
74$search_usertoprocessid =
GETPOSTINT(
'search_usertoprocessid');
75$search_task_ref =
GETPOST(
'search_task_ref',
'alpha');
76$search_task_label =
GETPOST(
'search_task_label',
'alpha');
77$search_project_ref =
GETPOST(
'search_project_ref',
'alpha');
78$search_thirdparty =
GETPOST(
'search_thirdparty',
'alpha');
79$search_declared_progress =
GETPOST(
'search_declared_progress',
'alpha');
81$sortfield =
GETPOST(
'sortfield',
'aZ09comma');
82$sortorder =
GETPOST(
'sortorder',
'aZ09comma');
86$prev = $startdayarray;
87$prev_year = $prev[
'year'];
88$prev_month = $prev[
'month'];
92$next_year = $next[
'year'];
93$next_month = $next[
'month'];
96$firstdaytoshow =
dol_mktime(0, 0, 0, $month, 1, $year);
98$TFirstDays[reset($TWeek)] =
'01';
100$TLastDays[end($TWeek)] = date(
"t", strtotime($year.
'-'.$month.
'-'.$day));
101if (empty($search_usertoprocessid) || $search_usertoprocessid == $user->id) {
102 $usertoprocess = $user;
103 $search_usertoprocessid = $usertoprocess->id;
104} elseif ($search_usertoprocessid > 0) {
105 $usertoprocess =
new User($db);
106 $usertoprocess->fetch($search_usertoprocessid);
107 $search_usertoprocessid = $usertoprocess->id;
109 $usertoprocess =
new User($db);
118$extrafields->fetch_name_optionals_label(
$object->table_element);
121$arrayfields = array();
130$arrayfields[
't.planned_workload'] = array(
'label' =>
'PlannedWorkload',
'checked' => 1,
'enabled' => 1,
'position' => 5);
131$arrayfields[
't.progress'] = array(
'label' =>
'ProgressDeclared',
'checked' => 1,
'enabled' => 1,
'position' => 10);
132$arrayfields[
'timeconsumed'] = array(
'label' =>
'TimeConsumed',
'checked' => 1,
'enabled' => 1,
'position' => 15);
140if (!empty($extrafields->attributes[
'projet_task'][
'label']) && is_array($extrafields->attributes[
'projet_task'][
'label']) && count($extrafields->attributes[
'projet_task'][
'label']) > 0) {
141 foreach ($extrafields->attributes[
'projet_task'][
'label'] as $key => $val) {
142 if (!empty($extrafields->attributes[
'projet_task'][
'list'][$key])) {
143 $arrayfields[
"efpt.".$key] = array(
'label' => $extrafields->attributes[
'projet_task'][
'label'][$key],
'checked' => (($extrafields->attributes[
'projet_task'][
'list'][$key] < 0) ? 0 : 1),
'position' => $extrafields->attributes[
'projet_task'][
'pos'][$key],
'enabled' => (abs((int) $extrafields->attributes[
'projet_task'][
'list'][$key]) != 3 && $extrafields->attributes[
'projet_task'][
'perms'][$key]));
149$search_array_options = array();
150$search_array_options_project = $extrafields->getOptionalsFromPost(
'projet',
'',
'search_');
151$search_array_options_task = $extrafields->getOptionalsFromPost(
'projet_task',
'',
'search_task_');
160$parameters = array(
'id' => $id,
'taskid' => $taskid,
'projectid' => $projectid,
'TWeek' => $TWeek,
'TFirstDays' => $TFirstDays,
'TLastDays' => $TLastDays);
161$reshook = $hookmanager->executeHooks(
'doActions', $parameters, $object, $action);
167if (
GETPOST(
'button_removefilter_x',
'alpha') ||
GETPOST(
'button_removefilter.x',
'alpha') ||
GETPOST(
'button_removefilter',
'alpha')) {
170 $search_usertoprocessid = $user->id;
171 $search_task_ref =
'';
172 $search_task_label =
'';
173 $search_project_ref =
'';
174 $search_thirdparty =
'';
175 $search_declared_progress =
'';
177 $search_array_options_project = array();
178 $search_array_options_task = array();
181 $usertoprocess = $user;
183if (
GETPOST(
"button_search_x",
'alpha') ||
GETPOST(
"button_search.x",
'alpha') ||
GETPOST(
"button_search",
'alpha')) {
187if (
GETPOST(
'submitdateselect')) {
195include DOL_DOCUMENT_ROOT.
'/core/actions_changeselectedfields.inc.php';
197if ($action ==
'addtime' && $user->hasRight(
'projet',
'lire') &&
GETPOST(
'assigntask') &&
GETPOST(
'formfilteraction') !=
'listafterchangingselectedfields') {
198 $action =
'assigntask';
201 $result =
$object->fetch($taskid, $ref);
206 setEventMessages($langs->transnoentitiesnoconv(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Task")),
null,
'errors');
210 setEventMessages($langs->transnoentitiesnoconv(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Type")),
null,
'errors');
215 $idfortaskuser = $usertoprocess->id;
216 $result =
$object->add_contact($idfortaskuser,
GETPOST(
"type"),
'internal');
218 if ($result >= 0 || $result == -2) {
220 $sql =
'SELECT ec.rowid FROM '.MAIN_DB_PREFIX.
'element_contact as ec, '.MAIN_DB_PREFIX.
'c_type_contact as tc WHERE tc.rowid = ec.fk_c_type_contact';
221 $sql .=
' AND ec.fk_socpeople = '.((int) $idfortaskuser).
" AND ec.element_id = ".((int)
$object->fk_project).
" AND tc.element = 'project' AND source = 'internal'";
222 $resql = $db->query($sql);
224 $obj = $db->fetch_object($resql);
227 $project->fetch(
$object->fk_project);
229 $listofprojcontact = $project->liste_type_contact(
'internal');
231 if (count($listofprojcontact)) {
232 $tmparray = array_keys($listofprojcontact);
233 $typeforprojectcontact = reset($tmparray);
234 $result = $project->add_contact($idfortaskuser, $typeforprojectcontact,
'internal');
245 if (
$object->error ==
'DB_ERROR_RECORD_ALREADY_EXISTS') {
246 $langs->load(
"errors");
247 setEventMessages($langs->trans(
"ErrorTaskAlreadyAssigned"),
null,
'warnings');
261if ($action ==
'addtime' && $user->hasRight(
'projet',
'lire') &&
GETPOST(
'formfilteraction') !=
'listafterchangingselectedfields') {
263 if (empty($timetoadd)) {
266 foreach ($timetoadd as $tmptaskid => $tmpvalue) {
267 $updateoftaskdone = 0;
268 foreach ($tmpvalue as $key => $val) {
269 $amountoadd = $timetoadd[$tmptaskid][$key];
270 if (!empty($amountoadd)) {
271 $tmpduration = explode(
':', $amountoadd);
273 if (!empty($tmpduration[0])) {
274 $newduration += (int) ((
float) $tmpduration[0] * 3600);
276 if (!empty($tmpduration[1])) {
277 $newduration += (int) ((
float) $tmpduration[1] * 60);
279 if (!empty($tmpduration[2])) {
280 $newduration += ((int) $tmpduration[2]);
283 if ($newduration > 0) {
286 if (GETPOSTISSET($tmptaskid.
'progress')) {
292 $object->timespent_duration = $newduration;
293 $object->timespent_fk_user = $usertoprocess->id;
298 $result =
$object->addTimeSpent($user);
310 if (!$updateoftaskdone) {
316 $result =
$object->update($user);
330 $param .= ($mode ?
'&mode='.urlencode($mode) :
'');
331 $param .= ($projectid ?
'id='.urlencode((
string) ($projectid)) :
'');
332 $param .= ($search_usertoprocessid ?
'&search_usertoprocessid='.urlencode((
string) $search_usertoprocessid) :
'');
333 $param .= ($day ?
'&day='.urlencode((
string) ($day)) :
'').($month ?
'&month='.urlencode((
string) ($month)) :
'').($year ?
'&year='.urlencode((
string) ($year)) :
'');
334 $param .= ($search_project_ref ?
'&search_project_ref='.urlencode($search_project_ref) :
'');
335 $param .= ($search_usertoprocessid > 0 ?
'&search_usertoprocessid='.urlencode((
string) $search_usertoprocessid) :
'');
336 $param .= ($search_thirdparty ?
'&search_thirdparty='.urlencode($search_thirdparty) :
'');
337 $param .= ($search_declared_progress ?
'&search_declared_progress='.urlencode($search_declared_progress) :
'');
338 $param .= ($search_task_ref ?
'&search_task_ref='.urlencode($search_task_ref) :
'');
339 $param .= ($search_task_label ?
'&search_task_label='.urlencode($search_task_label) :
'');
346 $search_array_options = $search_array_options_task;
347 $search_options_pattern =
'search_task_options_';
348 include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_list_search_param.tpl.php';
351 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?'.$param);
363$form =
new Form($db);
367$projectstatic =
new Project($db);
369$taskstatic =
new Task($db);
370$thirdpartystatic =
new Societe($db);
373$title = $langs->trans(
"TimeSpent");
375$projectsListId = $projectstatic->getProjectsAuthorizedForUser($usertoprocess, (empty($usertoprocess->id) ? 2 : 0), 1);
378 $project->fetch($id);
379 $project->fetch_thirdparty();
382$onlyopenedproject = 1;
383$morewherefilter =
'';
385if ($search_project_ref) {
386 $morewherefilter .=
natural_search(array(
"p.ref",
"p.title"), $search_project_ref);
388if ($search_task_ref) {
391if ($search_task_label) {
392 $morewherefilter .=
natural_search(array(
"t.ref",
"t.label"), $search_task_label);
394if ($search_thirdparty) {
397if ($search_declared_progress) {
398 $morewherefilter .=
natural_search(
"t.progress", $search_declared_progress, 1);
401$sql = &$morewherefilter;
409$search_array_options = $search_array_options_task;
410$extrafieldsobjectprefix =
'efpt.';
411$search_options_pattern =
'search_task_options_';
412$extrafieldsobjectkey =
'projet_task';
413include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_list_search_sql.tpl.php';
415$tasksarraywithoutfilter = array();
417$tasksarray = $taskstatic->getTasksArray(
null,
null, ($project->id ? $project->id : 0), $socid, 0, $search_project_ref, $onlyopenedproject, $morewherefilter, ($search_usertoprocessid ? $search_usertoprocessid : 0), 0, $extrafields);
418if ($morewherefilter) {
419 $tasksarraywithoutfilter = $taskstatic->getTasksArray(
null,
null, ($project->id ? $project->id : 0), $socid, 0,
'', $onlyopenedproject,
'', ($search_usertoprocessid ? $search_usertoprocessid : 0));
421$projectsrole = $taskstatic->getUserRolesForProjectsOrTasks($usertoprocess,
null, ($project->id ? $project->id : 0), 0, $onlyopenedproject);
422$tasksrole = $taskstatic->getUserRolesForProjectsOrTasks(
null, $usertoprocess, ($project->id ? $project->id : 0), 0, $onlyopenedproject);
428llxHeader(
'', $title,
'',
'', 0, 0, array(
'/core/js/timesheet.js'),
'',
'',
'mod-project project-activity page-activity_permonth');
433$param .= ($mode ?
'&mode='.urlencode($mode) :
'');
434$param .= ($search_project_ref ?
'&search_project_ref='.urlencode($search_project_ref) :
'');
435$param .= ($search_usertoprocessid > 0 ?
'&search_usertoprocessid='.urlencode((
string) $search_usertoprocessid) :
'');
436$param .= ($search_thirdparty ?
'&search_thirdparty='.urlencode($search_thirdparty) :
'');
437$param .= ($search_task_ref ?
'&search_task_ref='.urlencode($search_task_ref) :
'');
438$param .= ($search_task_label ?
'&search_task_label='.urlencode($search_task_label) :
'');
440$search_array_options = $search_array_options_project;
441$search_options_pattern =
'search_options_';
442include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_list_search_param.tpl.php';
444$search_array_options = $search_array_options_task;
445$search_options_pattern =
'search_task_options_';
446include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_list_search_param.tpl.php';
449$nav =
'<a class="inline-block valignmiddle" href="?year='.$prev_year.
"&month=".$prev_month.
"&day=".$prev_day.$param.
'">'.
img_previous($langs->trans(
"Previous")).
"</a>\n";
450$nav .=
' <span id="month_name">'.dol_print_date(
dol_mktime(0, 0, 0, $month, 1, $year),
"%Y").
", ".$langs->trans(date(
'F', mktime(0, 0, 0, $month, 10))).
" </span>\n";
451$nav .=
'<a class="inline-block valignmiddle" href="?year='.$next_year.
"&month=".$next_month.
"&day=".$next_day.$param.
'">'.
img_next($langs->trans(
"Next")).
"</a>\n";
452$nav .=
' '.$form->selectDate(-1,
'', 0, 0, 2,
"addtime", 1, ($conf->dol_optimize_smallscreen ? 0 : 1)).
' ';
453$nav .=
' <button type="submit" name="submitdateselect" value="x" class="bordertransp nobordertransp button_search_x"><span class="fa fa-search"></span></button>';
457print
'<form name="addtime" method="POST" action="'.$_SERVER[
"PHP_SELF"].
'">';
458print
'<input type="hidden" name="token" value="'.newToken().
'">';
459print
'<input type="hidden" name="action" value="addtime">';
460print
'<input type="hidden" name="formfilteraction" id="formfilteraction" value="list">';
461print
'<input type="hidden" name="contextpage" value="'.$contextpage.
'">';
462print
'<input type="hidden" name="mode" value="'.$mode.
'">';
463print
'<input type="hidden" name="day" value="'.$day.
'">';
464print
'<input type="hidden" name="month" value="'.$month.
'">';
465print
'<input type="hidden" name="year" value="'.$year.
'">';
468print
dol_get_fiche_head($head,
'inputpermonth', $langs->trans(
'TimeSpent'), -1, $picto);
471print
'<div class="hideonsmartphone opacitymedium">';
472if ($mine || ($usertoprocess->id == $user->id)) {
473 print $langs->trans(
"MyTasksDesc").
'.'.($onlyopenedproject ?
' '.$langs->trans(
"OnlyOpenedProject") :
'').
'<br>';
475 if (empty($usertoprocess->id) || $usertoprocess->id < 0) {
476 if ($user->hasRight(
'projet',
'all',
'lire') && !$socid) {
477 print $langs->trans(
"ProjectsDesc").
'.'.($onlyopenedproject ?
' '.$langs->trans(
"OnlyOpenedProject") :
'').
'<br>';
479 print $langs->trans(
"ProjectsPublicTaskDesc").
'.'.($onlyopenedproject ?
' '.$langs->trans(
"OnlyOpenedProject") :
'').
'<br>';
483if ($mine || ($usertoprocess->id == $user->id)) {
484 print $langs->trans(
"OnlyYourTaskAreVisible").
'<br>';
486 print $langs->trans(
"AllTaskVisibleButEditIfYouAreAssigned").
'<br>';
492print
'<div class="'.($conf->dol_optimize_smallscreen ?
'center centpercent' :
'floatright right').
'">'.$nav.
'</div>';
494print
'<div class="colorbacktimesheet valignmiddle'.($conf->dol_optimize_smallscreen ?
' center' :
' float').
'">';
495$titleassigntask = $langs->transnoentities(
"AssignTaskToMe");
496if ($usertoprocess->id != $user->id) {
497 $titleassigntask = $langs->transnoentities(
"AssignTaskToUser", $usertoprocess->getFullName($langs));
499print
'<div class="taskiddiv inline-block">';
500print
img_picto(
'',
'projecttask',
'class="pictofixedwidth"');
501$formproject->selectTasks($socid ? $socid : -1, $taskid,
'taskid', 32, 0,
'-- '.$langs->trans(
"ChooseANotYetAssignedTask").
' --', 1, 0, 0,
'widthcentpercentminusx',
'',
'all', $usertoprocess);
504print $formcompany->selectTypeContact($object,
'',
'type',
'internal',
'position', 0,
'maxwidth150onsmartphone');
505print
'<input type="submit" class="button valignmiddle smallonsmartphone small" name="assigntask" value="'.dol_escape_htmltag($titleassigntask).
'">';
508print
'<div class="clearboth" style="padding-bottom: 20px;"></div>';
524$includeonly =
'hierarchyme';
525if (!$user->hasRight(
'user',
'user',
'lire')) {
526 $includeonly = array($user->id);
528$selecteduser = $search_usertoprocessid ? $search_usertoprocessid : $usertoprocess->id;
529$moreforfiltertmp = $form->select_dolusers($selecteduser,
'search_usertoprocessid', 0,
null, 0, $includeonly, array(), 0, 0, 0,
'', 0,
'',
'maxwidth200');
530if ($form->num > 1 || empty($conf->dol_optimize_smallscreen)) {
531 $moreforfilter .=
'<div class="divsearchfield">';
532 $moreforfilter .=
'<div class="inline-block hideonsmartphone"></div>';
533 $moreforfilter .=
img_picto($langs->trans(
'Filter').
' '.$langs->trans(
'User'),
'user',
'class="paddingright pictofixedwidth"');
534 $moreforfilter .= $moreforfiltertmp;
535 $moreforfilter .=
'</div>';
537 $moreforfilter .=
'<input type="hidden" name="search_usertoprocessid" value="'.$selecteduser.
'">';
541 $moreforfilter .=
'<div class="divsearchfield">';
542 $moreforfilter .=
'<div class="inline-block"></div>';
543 $moreforfilter .=
img_picto($langs->trans(
'Filter').
' '.$langs->trans(
'Project'),
'project',
'class="paddingright pictofixedwidth"').
'<input type="text" name="search_project_ref" class="maxwidth100" value="'.
dol_escape_htmltag($search_project_ref).
'">';
544 $moreforfilter .=
'</div>';
546 $moreforfilter .=
'<div class="divsearchfield">';
547 $moreforfilter .=
'<div class="inline-block"></div>';
548 $moreforfilter .=
img_picto($langs->trans(
'Filter').
' '.$langs->trans(
'ThirdParty'),
'company',
'class="paddingright pictofixedwidth"').
'<input type="text" name="search_thirdparty" class="maxwidth100" value="'.
dol_escape_htmltag($search_thirdparty).
'">';
549 $moreforfilter .=
'</div>';
552if (!empty($moreforfilter)) {
553 print
'<div class="liste_titre liste_titre_bydiv centpercent">';
554 print $moreforfilter;
555 $parameters = array();
556 $reshook = $hookmanager->executeHooks(
'printFieldPreListTitle', $parameters, $object, $action);
557 print $hookmanager->resPrint;
561$varpage = empty($contextpage) ? $_SERVER[
"PHP_SELF"] : $contextpage;
563$selectedfields = $form->multiSelectArrayWithCheckbox(
'selectedfields', $arrayfields, $varpage);
567if (!empty($arrayfields[
't.planned_workload'][
'checked'])) {
570if (!empty($arrayfields[
't.progress'][
'checked'])) {
573foreach ($arrayfields as $key => $val) {
574 if ($val[
'checked'] && substr($key, 0, 5) ==
'efpt.') {
579print
'<div class="div-table-responsive">';
581print
'<table class="tagtable liste'.($moreforfilter ?
" listwithfilterbefore" :
"").
'" id="tablelines3">'.
"\n";
583print
'<tr class="liste_titre_filter">';
585 print
'<td class="liste_titre"><input type="text" size="4" name="search_project_ref" value="'.dol_escape_htmltag($search_project_ref).
'"></td>';
588 print
'<td class="liste_titre"><input type="text" size="4" name="search_thirdparty" value="'.dol_escape_htmltag($search_thirdparty).
'"></td>';
590print
'<td class="liste_titre"><input type="text" size="4" name="search_task_label" value="'.dol_escape_htmltag($search_task_label).
'"></td>';
591if (!empty($arrayfields[
't.planned_workload'][
'checked'])) {
592 print
'<td class="liste_titre"></td>';
594if (!empty($arrayfields[
't.progress'][
'checked'])) {
595 print
'<td class="liste_titre right"><input type="text" size="4" name="search_declared_progress" value="'.dol_escape_htmltag($search_declared_progress).
'"></td>';
597if (!empty($arrayfields[
'timeconsumed'][
'checked'])) {
598 print
'<td class="liste_titre"></td>';
599 print
'<td class="liste_titre"></td>';
601foreach ($TWeek as $week_number) {
602 print
'<td class="liste_titre"></td>';
605print
'<td class="liste_titre nowrap right">';
606$searchpicto = $form->showFilterAndCheckAddButtons(0);
611print
'<tr class="liste_titre">';
613 print
'<td>'.$langs->trans(
"Project").
'</td>';
616 print
'<td>'.$langs->trans(
"ThirdParty").
'</td>';
618print
'<td>'.$langs->trans(
"Task").
'</td>';
619if (!empty($arrayfields[
't.planned_workload'][
'checked'])) {
620 print
'<td align="right" class="leftborder plannedworkload maxwidth75">'.$form->textwithpicto($langs->trans(
"PlannedWorkloadShort"), $langs->trans(
"PlannedWorkload")).
'</td>';
622if (!empty($arrayfields[
't.progress'][
'checked'])) {
623 print
'<td class="right maxwidth75">'.$langs->trans(
"ProgressDeclared").
'</td>';
625if (!empty($arrayfields[
'timeconsumed'][
'checked'])) {
626 print
'<td class="right maxwidth100">'.$langs->trans(
"TimeSpentSmall").
'<br>';
627 print
'<span class="nowraponall">';
628 print
'<span class="opacitymedium nopadding userimg"><img alt="Photo" class="photouserphoto userphoto" src="'.DOL_URL_ROOT.
'/theme/common/everybody.png"></span>';
629 print
'<span class="opacitymedium paddingleft">'.$langs->trans(
"EverybodySmall").
'</span>';
632 print
'<td class="right maxwidth75">'.$langs->trans(
"TimeSpentSmall").($usertoprocess->firstname ?
'<br><span class="nowraponall">'.$usertoprocess->getNomUrl(-2).
'<span class="opacitymedium paddingleft">'.
dol_trunc($usertoprocess->firstname, 10).
'</span></span>' :
'').
'</td>';
634foreach ($TWeek as $week_number) {
635 print
'<td width="6%" class="center bold hide"><a href="'.DOL_URL_ROOT.
'/projet/activity/perweek.php?year='.$year.
'&month='.$month.
'&day='.$TFirstDays[$week_number].
'">'.$langs->trans(
"WeekShort").
' '.$week_number.
'<br>('.$TFirstDays[$week_number].
'...'.$TLastDays[$week_number].
')</a></td>';
639print_liste_field_titre($selectedfields, $_SERVER[
"PHP_SELF"],
"",
'',
'',
'', $sortfield, $sortorder,
'center maxwidthsearch ');
647$isavailable = array();
651$restrictviewformytask =
getDolGlobalInt(
'PROJECT_TIME_SHOW_TASK_NOT_ASSIGNED', 2);
652if (count($tasksarray) > 0) {
659 $totalforvisibletasks =
projectLinesPerMonth($j, $firstdaytoshow, $usertoprocess, 0, $tasksarray, $level, $projectsrole, $tasksrole, $mine, $restrictviewformytask, $isavailable, 0, $TWeek, $arrayfields);
665 $listofdistinctprojectid = array();
666 if (!empty($tasksarraywithoutfilter) && is_array($tasksarraywithoutfilter) && count($tasksarraywithoutfilter)) {
667 foreach ($tasksarraywithoutfilter as $tmptask) {
668 $listofdistinctprojectid[$tmptask->fk_project] = $tmptask->fk_project;
672 $totalforeachweek = array();
673 '@phan-var-force array<string,int> $totalforeachweek';
675 foreach ($listofdistinctprojectid as $tmpprojectid) {
676 $projectstatic->id = $tmpprojectid;
677 $projectstatic->loadTimeSpentMonth($firstdaytoshow, 0, $usertoprocess->id);
678 foreach ($TWeek as $weekNb) {
679 $totalforeachweek[$weekNb] += $projectstatic->monthWorkLoad[$weekNb];
688 if (count($totalforeachweek)) {
689 foreach ($TWeek as $weekNb) {
690 $timeonothertasks = ($totalforeachweek[$weekNb] - $totalforvisibletasks[$weekNb]);
691 if ($timeonothertasks) {
700 print
'<tr class="oddeven othertaskwithtime">';
701 print
'<td colspan="'.$colspan.
'" class="opacitymedium">';
702 print $langs->trans(
"OtherFilteredTasks");
704 if (!empty($arrayfields[
't.planned_workload'][
'checked'])) {
705 print
'<td class="liste_total"></td>';
707 if (!empty($arrayfields[
't.progress'][
'checked'])) {
708 print
'<td class="liste_total"></td>';
710 if (!empty($arrayfields[
'timeconsumed'][
'checked'])) {
711 print
'<td class="liste_total"></td>';
712 print
'<td class="liste_total"></td>';
715 foreach ($TWeek as $weekNb) {
717 print
'<td class="center hide'.($j <= 1 ?
' borderleft' :
'').
'">';
719 $timeonothertasks = ($totalforeachweek[$weekNb] - $totalforvisibletasks[$weekNb]);
720 if ($timeonothertasks) {
721 print
'<span class="timesheetalreadyrecorded" title="texttoreplace"><input type="text" class="center smallpadd width40" disabled="" id="timespent[-1]['.$weekNb.
']" name="task[-1]['.$weekNb.
']" value="';
727 print
' <td class="liste_total"></td>';
731 if ($conf->use_javascript_ajax) {
732 print
'<tr class="liste_total">';
733 print
'<td class="liste_total" colspan="'.($colspan + $addcolspan).
'">';
734 print $langs->trans(
"Total");
735 print
'<span class="opacitymediumbycolor"> - '.$langs->trans(
"ExpectedWorkedHours").
': <strong>'.
price($usertoprocess->weeklyhours, 1, $langs, 0, 0).
'</strong></span>';
737 if (!empty($arrayfields[
'timeconsumed'][
'checked'])) {
738 print
'<td class="liste_total"></td>';
739 print
'<td class="liste_total"></td>';
743 foreach ($TWeek as $weekNb) {
745 print
'<td class="liste_total hide'.$weekNb.
' center'.($j <= 1 ?
' borderleft' :
'').
'"><div class="totalDay'.$weekNb.
'">'.
convertSecondToTime($totalforvisibletasks[$weekNb],
'allhourmin').
'</div></td>';
747 print
'<td class="liste_total center"><div class="totalDayAll"> </div></td>
751 $THolidays = array();
752 $totaldayholiday = 0;
753 foreach ($TWeek as $weekNb) {
757 $filter .=
" AND ('".$db->idate($weekstart).
"' BETWEEN cp.date_debut AND cp.date_fin";
758 $filter .=
" OR '".$db->idate($weekend).
"' BETWEEN cp.date_debut AND cp.date_fin)";
759 $holiday->fetchByUser($usertoprocess->id,
'', $filter);
760 $THolidays[$weekNb] = array();
761 $THolidays[$weekNb][
"ids"] = array();
762 $THolidays[$weekNb][
"days"] = 0;
763 foreach ($holiday->holiday as $key => $h) {
764 if (!empty($THolidays[$weekNb][
"ids"]) && in_array($h->rowid, $THolidays[$weekNb][
"ids"])) {
767 $startweekholiday =(int) (($h[
"date_debut"] <= $weekstart) ? $weekstart : $h[
"date_debut"] );
768 $endweekholiday =(int) (($h[
"date_fin"] >= $weekend) ? $weekend : $h[
"date_fin"]);
769 $halfdays = (int) $h[
"halfday"];
770 $nbdays =
num_open_day($startweekholiday, $endweekholiday, 0, 1, $halfdays);
772 $THolidays[$weekNb][
"ids"][] = $h->rowid;
773 $THolidays[$weekNb][
"days"] += $nbdays;
774 $totaldayholiday += $nbdays;
779 print
'<tr class="liste_total">';
780 print
'<td class="liste_total" colspan="'.($colspan + $addcolspan).
'">';
781 print $langs->trans(
"Total");
782 print
'<span class="opacitymediumbycolor"> - '.$langs->trans(
"NbUseDaysCP").
': <strong>'.
price($totaldayholiday, 1, $langs, 0, 0).
'</strong></span>';
784 if (!empty($arrayfields[
'timeconsumed'][
'checked'])) {
785 print
'<td class="liste_total"></td>';
786 print
'<td class="liste_total"></td>';
789 foreach ($TWeek as $weekNb) {
791 print
'<td class="liste_total_holidays '.($THolidays[$weekNb][
"days"] > 0 ?
"onholidayallday" :
"").
' hide'.$weekNb.
' center'.($j <= 1 ?
' borderleft' :
'').
'"><div class="totalDay'.$weekNb.
'holidays">'.$THolidays[$weekNb][
"days"].
'</div></td>';
793 print
'<td class="liste_total_holidays center"><div class="totalDayAllHolidays"> </div></td>
796 print
'<tr><td colspan="15"><span class="opacitymedium">'.$langs->trans(
"NoAssignedTasks").
'</span></td></tr>';
801print
'<input type="hidden" id="numberOfLines" name="numberOfLines" value="'.count($tasksarray).
'"/>'.
"\n";
802print
'<input type="hidden" id="numberOfFirstLine" name="numberOfFirstLine" value="'.(reset($TWeek)).
'"/>'.
"\n";
804print $form->buttonsSaveCancel(
"Save",
'');
806print
'</form>'.
"\n\n";
810if ($conf->use_javascript_ajax) {
811 print
"\n<!-- JS CODE TO ENABLE Tooltips on all object with class classfortooltip -->\n";
812 print
'<script type="text/javascript">'.
"\n";
813 print
"jQuery(document).ready(function () {\n";
814 print
' jQuery(".timesheetalreadyrecorded").tooltip({
815 show: { collision: "flipfit", effect:\'toggle\', delay:50 },
816 hide: { effect:\'toggle\', delay: 50 },
817 tooltipClass: "mytooltip",
818 content: function () {
819 return \''.dol_escape_js($langs->trans(
"TimeAlreadyRecorded", $usertoprocess->getFullName($langs))).
'\';
823 foreach ($TWeek as $week_number) {
824 print " updateTotal(".((int) $week_number).", '".dol_escape_js($modeinput)."');";
if( $user->socid > 0) if(! $user->hasRight('accounting', 'chartofaccount')) $object
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 of the module paid holiday.
const STATUS_APPROVED
Approved.
Class to manage projects.
Class to manage third parties objects (customers, suppliers, prospects...)
Class to manage Dolibarr users.
dol_get_prev_month($month, $year)
Return previous month.
getLastDayOfEachWeek($TWeek, $year)
Return array of last day of weeks.
getWeekNumbersOfMonth($month, $year)
Return array of week numbers.
getFirstDayOfEachWeek($TWeek, $year)
Return array of first day of weeks.
dol_get_next_month($month, $year)
Return next month.
num_open_day($timestampStart, $timestampEnd, $inhour=0, $lastday=0, $halfday=0, $country_code='')
Function to return number of working days (and text of units) between two dates (working days)
dol_time_plus_duree($time, $duration_value, $duration_unit, $ruleforendofmonth=0)
Add a delay to a date.
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...
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.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0)
Show tabs of a record.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
natural_search($fields, $value, $mode=0, $nofirstand=0)
Generate natural SQL search string for a criteria (this criteria can be tested on one or several fiel...
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_now($mode='auto')
Return date for now.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
dol_sort_array(&$array, $index, $order='asc', $natsort=0, $case_sensitive=0, $keepindex=0)
Advanced sort array by the value of a given key, which produces ascending (default) or descending out...
print_liste_field_titre($name, $file="", $field="", $begin="", $moreparam="", $moreattrib="", $sortfield="", $sortorder="", $prefix="", $tooltip="", $forcenowrapcolumntitle=0)
Show title line of an array.
img_previous($titlealt='default', $moreatt='')
Show previous logo.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
img_next($titlealt='default', $moreatt='')
Show next logo.
dol_trunc($string, $size=40, $trunc='right', $stringencoding='UTF-8', $nodot=0, $display=0)
Truncate a string to a particular length adding '…' if string larger than length.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
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_timesheet_prepare_head($mode, $fuser=null)
Prepare array with list of tabs.
projectLinesPerMonth(&$inc, $firstdaytoshow, $fuser, $parent, $lines, &$level, &$projectsrole, &$tasksrole, $mine, $restricteditformytask, &$isavailable, $oldprojectforbreak=0, $TWeek=array(), $arrayfields=array(), $extrafields=null)
Output a task line into a perday input mode.
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.