* Copyright (C) 2003 Eric Seigne * Copyright (C) 2004-2014 Laurent Destailleur * Copyright (C) 2005-2012 Regis Houssin * Copyright (C) 2011 Juanjo Menent * Copyright (C) 2014 Cedric GROSS * Copyright (C) 2018-2025 Frédéric France * Copyright (C) 2023 Florian HENRY * Copyright (C) 2024 MDW * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ /** * \file htdocs/comm/action/peruser.php * \ingroup agenda * \brief Tab of calendar events per user */ // Load Dolibarr environment require '../../main.inc.php'; require_once DOL_DOCUMENT_ROOT.'/comm/action/class/actioncomm.class.php'; require_once DOL_DOCUMENT_ROOT.'/societe/class/societe.class.php'; require_once DOL_DOCUMENT_ROOT.'/contact/class/contact.class.php'; require_once DOL_DOCUMENT_ROOT.'/user/class/usergroup.class.php'; require_once DOL_DOCUMENT_ROOT.'/core/lib/date.lib.php'; require_once DOL_DOCUMENT_ROOT.'/core/lib/agenda.lib.php'; require_once DOL_DOCUMENT_ROOT.'/core/class/html.formprojet.class.php'; require_once DOL_DOCUMENT_ROOT.'/projet/class/project.class.php'; /** * @var Conf $conf * @var DoliDB $db * @var HookManager $hookmanager * @var Translate $langs * @var User $user */ $MAXAGENDA = getDolGlobalString('AGENDA_EXT_NB', 5); $DELAYFORCACHE = 300; // 300 seconds $disabledefaultvalues = GETPOSTINT('disabledefaultvalues'); $check_holiday = GETPOSTINT('check_holiday'); $filter = GETPOST("search_filter", 'alpha', 3) ? GETPOST("search_filter", 'alpha', 3) : GETPOST("filter", 'alpha', 3); $filtert = GETPOSTINT("search_filtert", 3) ? GETPOSTINT("search_filtert", 3) : GETPOSTINT("filtert", 3); $usergroup = GETPOSTINT("search_usergroup", 3) ? GETPOSTINT("search_usergroup", 3) : GETPOSTINT("usergroup", 3); //if (! ($usergroup > 0) && ! ($filtert > 0)) $filtert = $user->id; //$showbirthday = empty($conf->use_javascript_ajax)?GETPOST("showbirthday","int"):1; $showbirthday = getDolGlobalInt('AGENDA_ENABLE_SHOW_BIRTHDAY_PER_USER'); // disabled by default // If no choice done on calendar owner (like on left menu link "Agenda"), we filter on current user by default. /*if (empty($filtert) && !getDolGlobalString('AGENDA_ALL_CALENDARS')) { $filtert = (string) $user->id; }*/ $sortfield = GETPOST('sortfield', 'aZ09comma'); $sortorder = GETPOST('sortorder', 'aZ09comma'); $page = GETPOSTISSET('pageplusone') ? (GETPOSTINT('pageplusone') - 1) : GETPOSTINT("page"); if (empty($page) || $page == -1) { $page = 0; } // If $page is not defined, or '' or -1 $limit = GETPOSTINT('limit') ? GETPOSTINT('limit') : $conf->liste_limit; $offset = $limit * $page; if (!$sortorder) { $sortorder = "ASC"; } if (!$sortfield) { $sortfield = "a.datec"; } // Security check $socid = GETPOSTINT("search_socid") ? GETPOSTINT("search_socid") : GETPOSTINT("socid"); if ($user->socid) { $socid = $user->socid; } if ($socid < 0) { $socid = ''; } $canedit = 1; if (!$user->hasRight('agenda', 'myactions', 'read')) { accessforbidden(); } if (!$user->hasRight('agenda', 'allactions', 'read')) { $canedit = 0; } if (!$user->hasRight('agenda', 'allactions', 'read') || $filter == 'mine') { // If no permission to see all, we show only affected to me $filtert = (string) $user->id; } $action = GETPOST('action', 'aZ09'); $mode = 'show_peruser'; $resourceid = GETPOSTINT("search_resourceid") ? GETPOSTINT("search_resourceid") : GETPOSTINT("resourceid"); $year = GETPOSTINT("year") ? GETPOSTINT("year") : date("Y"); $month = GETPOSTINT("month") ? GETPOSTINT("month") : date("m"); $week = GETPOSTINT("week") ? GETPOSTINT("week") : date("W"); $day = GETPOSTINT("day") ? GETPOSTINT("day") : date("d"); $pid = GETPOSTISSET("search_projectid") ? GETPOSTINT("search_projectid", 3) : GETPOSTINT("projectid", 3); $status = GETPOSTISSET("search_status") ? GETPOST("search_status", 'aZ09') : GETPOST("status", 'aZ09'); // status may be 0, 50, 100, 'todo', 'na' or -1 $type = GETPOSTISSET("search_type") ? GETPOST("search_type", 'aZ09') : GETPOST("type", 'aZ09'); $maxprint = GETPOSTISSET("maxprint") ? GETPOSTINT("maxprint") : getDolGlobalInt('AGENDA_MAX_EVENTS_DAY_VIEW', 3); $optioncss = GETPOST('optioncss', 'aZ'); // Option for the css output (always '' except when 'print') $search_categ_cus = GETPOSTINT("search_categ_cus", 3) ? GETPOSTINT("search_categ_cus", 3) : 0; // Set actioncode (this code must be same for setting actioncode into peruser, listacton and index) if (GETPOST('search_actioncode', 'array:aZ09')) { $actioncode = GETPOST('search_actioncode', 'array:aZ09', 3); if (!count($actioncode)) { $actioncode = '0'; } } else { $actioncode = GETPOST("search_actioncode", "alpha", 3) ? GETPOST("search_actioncode", "alpha", 3) : (GETPOST("search_actioncode", "alpha") == '0' ? '0' : ((!getDolGlobalString('AGENDA_DEFAULT_FILTER_TYPE') || $disabledefaultvalues) ? '' : getDolGlobalString('AGENDA_DEFAULT_FILTER_TYPE'))); } $dateselect = dol_mktime(0, 0, 0, GETPOSTINT('dateselectmonth'), GETPOSTINT('dateselectday'), GETPOSTINT('dateselectyear')); if ($dateselect > 0) { $day = GETPOSTINT('dateselectday'); $month = GETPOSTINT('dateselectmonth'); $year = GETPOSTINT('dateselectyear'); } $tmp = getDolGlobalString('MAIN_DEFAULT_WORKING_HOURS', '9-18'); $tmp = str_replace(' ', '', $tmp); // FIX 7533 $tmparray = explode('-', $tmp); $begin_h = GETPOSTISSET('begin_h') ? GETPOSTINT('begin_h') : ($tmparray[0] != '' ? $tmparray[0] : 9); $end_h = GETPOSTISSET('end_h') ? GETPOSTINT('end_h') : ($tmparray[1] != '' ? $tmparray[1] : 18); if ($begin_h < 0 || $begin_h > 23) { $begin_h = 9; } if ($end_h < 1 || $end_h > 24) { $end_h = 18; } if ($end_h <= $begin_h) { $end_h = $begin_h + 1; } $tmp = getDolGlobalString('MAIN_DEFAULT_WORKING_DAYS', '1-5'); $tmp = str_replace(' ', '', $tmp); // FIX 7533 $tmparray = explode('-', $tmp); $begin_d = GETPOSTISSET('begin_d') ? GETPOSTINT('begin_d') : ($tmparray[0] != '' ? $tmparray[0] : 1); $end_d = GETPOSTISSET('end_d') ? GETPOSTINT('end_d') : ($tmparray[1] != '' ? $tmparray[1] : 5); if ($begin_d < 1 || $begin_d > 7) { $begin_d = 1; } if ($end_d < 1 || $end_d > 7) { $end_d = 7; } if ($end_d < $begin_d) { $end_d = $begin_d + 1; } if ($status == '' && !GETPOSTISSET('search_status')) { $status = ((!getDolGlobalString('AGENDA_DEFAULT_FILTER_STATUS') || $disabledefaultvalues) ? '' : getDolGlobalString('AGENDA_DEFAULT_FILTER_STATUS')); } if (empty($mode) && !GETPOSTISSET('mode')) { $mode = getDolGlobalString('AGENDA_DEFAULT_VIEW', 'show_peruser'); } if (GETPOST('viewcal', 'alpha') && $mode != 'show_day' && $mode != 'show_week' && $mode != 'show_peruser') { $mode = 'show_month'; $day = ''; } // View by month if (GETPOST('viewweek', 'alpha') || $mode == 'show_week') { $mode = 'show_week'; $week = ($week ? $week : date("W")); $day = ($day ? $day : date("d")); } // View by week if (GETPOST('viewday', 'alpha') || $mode == 'show_day') { $mode = 'show_day'; $day = ($day ? $day : date("d")); } // View by day $object = new ActionComm($db); // Load translation files required by the page $langs->loadLangs(array('users', 'agenda', 'other', 'commercial')); // Initialize a technical object to manage hooks of page. Note that conf->hooks_modules contains an array of hook context $hookmanager->initHooks(array('agenda')); $result = restrictedArea($user, 'agenda', 0, 'actioncomm&societe', 'myactions|allactions', 'fk_soc', 'id'); if ($user->socid && $socid) { $result = restrictedArea($user, 'societe', $socid); } $search_status = $status; /* * Actions */ // None /* * View */ $parameters = array( 'socid' => $socid, 'status' => $status, 'year' => $year, 'month' => $month, 'day' => $day, 'type' => $type, 'maxprint' => $maxprint, 'filter' => $filter, 'filtert' => $filtert, 'showbirthday' => $showbirthday, 'canedit' => $canedit, 'optioncss' => $optioncss, 'actioncode' => $actioncode, 'pid' => $pid, 'resourceid' => $resourceid, 'usergroup' => $usergroup, ); $reshook = $hookmanager->executeHooks('beforeAgendaPerUser', $parameters, $object, $action); // Note that $action and $object may have been modified by some hooks if ($reshook < 0) { setEventMessages($hookmanager->error, $hookmanager->errors, 'errors'); } $form = new Form($db); $companystatic = new Societe($db); $help_url = 'EN:Module_Agenda_En|FR:Module_Agenda|ES:Módulo_Agenda|DE:Modul_Terminplanung'; llxHeader('', $langs->trans("Agenda"), $help_url); $now = dol_now(); $nowarray = dol_getdate($now); $nowyear = $nowarray['year']; $nowmonth = $nowarray['mon']; $nowday = $nowarray['mday']; $listofextcals = array(); // Define list of all external calendars (global setup) if (!getDolGlobalString('AGENDA_DISABLE_EXT')) { $i = 0; while ($i < $MAXAGENDA) { $i++; $source = 'AGENDA_EXT_SRC'.$i; $name = 'AGENDA_EXT_NAME'.$i; $offsettz = 'AGENDA_EXT_OFFSETTZ'.$i; $color = 'AGENDA_EXT_COLOR'.$i; $default = 'AGENDA_EXT_ACTIVEBYDEFAULT'.$i; $buggedfile = 'AGENDA_EXT_BUGGEDFILE'.$i; if (getDolGlobalString($source) && getDolGlobalString($name)) { // Note: $conf->global->buggedfile can be empty or 'uselocalandtznodaylight' or 'uselocalandtzdaylight' $listofextcals[] = array( 'type' => 'globalsetup', 'src' => getDolGlobalString($source), 'name' => dol_string_nohtmltag(getDolGlobalString($name)), 'offsettz' => (int) getDolGlobalInt($offsettz, 0), 'color' => dol_string_nohtmltag(getDolGlobalString($color)), // @phan-suppress-next-line PhanPluginSuspiciousParamPosition 'default' => dol_string_nohtmltag(getDolGlobalString($default)), 'buggedfile' => dol_string_nohtmltag(getDolGlobalString('buggedfile', '')) ); } } } // Define list of external calendars (user setup) if (!getDolUserString('AGENDA_DISABLE_EXT')) { $i = 0; while ($i < $MAXAGENDA) { $i++; $source = 'AGENDA_EXT_SRC_'.$user->id.'_'.$i; $name = 'AGENDA_EXT_NAME_'.$user->id.'_'.$i; $offsettz = 'AGENDA_EXT_OFFSETTZ_'.$user->id.'_'.$i; $color = 'AGENDA_EXT_COLOR_'.$user->id.'_'.$i; $enabled = 'AGENDA_EXT_ENABLED_'.$user->id.'_'.$i; $default = 'AGENDA_EXT_ACTIVEBYDEFAULT_'.$user->id.'_'.$i; $buggedfile = 'AGENDA_EXT_BUGGEDFILE_'.$user->id.'_'.$i; if (getDolUserString($source) && getDolUserString($name)) { // Note: $conf->global->buggedfile can be empty or 'uselocalandtznodaylight' or 'uselocalandtzdaylight' $listofextcals[] = array( 'type' => 'usersetup', 'src' => getDolUserString($source), 'name' => dol_string_nohtmltag(getDolUserString($name)), 'offsettz' => (int) (empty($user->conf->$offsettz) ? 0 : $user->conf->$offsettz), 'color' => dol_string_nohtmltag(getDolUserString($color)), // @phan-suppress-next-line PhanPluginSuspiciousParamPosition 'default' => dol_string_nohtmltag(getDolUserString($default)), 'buggedfile' => dol_string_nohtmltag(isset($user->conf->buggedfile) ? $user->conf->buggedfile : '') ); } } } $prev = dol_get_first_day_week($day, $month, $year); $first_day = $prev['first_day']; $first_month = $prev['first_month']; $first_year = $prev['first_year']; $week = $prev['week']; $day = (int) $day; $next = dol_get_next_week($day, (int) $week, $month, $year); $next_year = $next['year']; $next_month = $next['month']; $next_day = $next['day']; $max_day_in_month = date("t", dol_mktime(0, 0, 0, $month, 1, $year)); $tmpday = $first_day; //print 'xx'.$prev_year.'-'.$prev_month.'-'.$prev_day; //print 'xx'.$next_year.'-'.$next_month.'-'.$next_day; $title = $langs->trans("DoneAndToDoActions"); if ($status == 'done') { $title = $langs->trans("DoneActions"); } if ($status == 'todo') { $title = $langs->trans("ToDoActions"); } $param = ''; if ($actioncode || GETPOSTISSET('search_actioncode')) { if (is_array($actioncode)) { foreach ($actioncode as $str_action) { $param .= "&search_actioncode[]=".urlencode($str_action); } } else { $param .= "&search_actioncode=".urlencode($actioncode); } } if ($resourceid > 0) { $param .= "&search_resourceid=".urlencode((string) ($resourceid)); } if ($status || GETPOSTISSET('status') || GETPOSTISSET('search_status')) { $param .= "&search_status=".urlencode($status); } if ($filter) { $param .= "&search_filter=".urlencode((string) $filter); } if ($filtert) { $param .= "&search_filtert=".urlencode((string) $filtert); } if ($usergroup > 0) { $param .= "&search_usergroup=".urlencode((string) ($usergroup)); } if ($socid > 0) { $param .= "&search_socid=".urlencode((string) ($socid)); } if ($showbirthday) { $param .= "&search_showbirthday=1"; } if ($pid) { $param .= "&search_projectid=".urlencode((string) ($pid)); } if ($type) { $param .= "&search_type=".urlencode($type); } if ($mode != 'show_peruser') { $param .= '&mode='.urlencode((string) $mode); } if ($begin_h != '') { $param .= '&begin_h='.((int) $begin_h); } if ($end_h != '') { $param .= '&end_h='.((int) $end_h); } if ($begin_d != '') { $param .= '&begin_d='.((int) $begin_d); } if ($end_d != '') { $param .= '&end_d='.((int) $end_d); } if ($search_categ_cus != 0) { $param .= '&search_categ_cus='.urlencode((string) ($search_categ_cus)); } $param .= "&maxprint=".urlencode((string) ($maxprint)); $paramnoactionodate = $param; $prev = dol_get_first_day_week($day, $month, $year); //print "day=".$day." month=".$month." year=".$year; //var_dump($prev); exit; $prev_year = $prev['prev_year']; $prev_month = $prev['prev_month']; $prev_day = $prev['prev_day']; $first_day = $prev['first_day']; $first_month = $prev['first_month']; $first_year = $prev['first_year']; $week = $prev['week']; $day = (int) $day; $next = dol_get_next_week($first_day, (int) $week, $first_month, $first_year); $next_year = $next['year']; $next_month = $next['month']; $next_day = $next['day']; // Define firstdaytoshow and lastdaytoshow. Warning: lastdaytoshow is last second to show + 1 // $firstdaytoshow and lastdaytoshow become a gmt dates to use to search/compare because first_xxx are in tz idea and we used tzuserrel $firstdaytoshow = dol_mktime(0, 0, 0, $first_month, $first_day, $first_year, 'tzuserrel'); $nb_weeks_to_show = (getDolGlobalString('AGENDA_NB_WEEKS_IN_VIEW_PER_USER')) ? ((int) $conf->global->AGENDA_NB_WEEKS_IN_VIEW_PER_USER * 7) : 7; $lastdaytoshow = dol_time_plus_duree($firstdaytoshow, $nb_weeks_to_show, 'd'); //print $firstday.'-'.$first_month.'-'.$first_year; //print dol_print_date($firstdaytoshow, 'dayhour', 'gmt'); //print dol_print_date($lastdaytoshow,'dayhour', 'gmt'); $max_day_in_month = idate("t", dol_mktime(0, 0, 0, $month, 1, $year, 'gmt')); $tmpday = $first_day; $picto = 'calendarweek'; // Show navigation bar $nav = ''; $nav .= $form->selectDate($dateselect, 'dateselect', 0, 0, 1, '', 1, 0); //$nav .= ' '; $nav .= ''; // Must be after the nav definition $paramnodate = $param; $param .= '&year='.$year.'&month='.$month.($day ? '&day='.$day : ''); //print 'x'.$param; $paramnoaction = preg_replace('/mode=[a-z_]+/', '', preg_replace('/action=[a-z_]+/', '', $param)); $paramnoactionodate = preg_replace('/mode=[a-z_]+/', '', preg_replace('/action=[a-z_]+/', '', $paramnodate)); $head = calendars_prepare_head($paramnoaction); print '
'."\n"; if ($optioncss != '') { print ''; } print ''; print ''; $mode = 'show_peruser'; $massactionbutton = ''; $viewmode = ''; $viewmode .= ''; $newparam = ''; $newcardbutton = ''; if ($user->hasRight('agenda', 'myactions', 'create') || $user->hasRight('agenda', 'allactions', 'create')) { $tmpforcreatebutton = dol_getdate(dol_now('tzuserrel'), true); $newparam .= '&month='.urlencode(str_pad((string) $month, 2, "0", STR_PAD_LEFT)).'&year='.((int) $tmpforcreatebutton['year']); if ($begin_h !== '') { $newparam .= '&begin_h='.((int) $begin_h); } if ($end_h !== '') { $newparam .= '&end_h='.((int) $end_h); } if ($begin_d !== '') { $newparam .= '&begin_d='.((int) $begin_d); } if ($end_d !== '') { $newparam .= '&end_d='.((int) $end_d); } $urltocreateaction = DOL_URL_ROOT.'/comm/action/card.php?action=create'; $urltocreateaction .= '&apyear='.$tmpforcreatebutton['year'].'&apmonth='.$tmpforcreatebutton['mon'].'&apday='.$tmpforcreatebutton['mday'].'&aphour='.$tmpforcreatebutton['hours'].'&apmin='.$tmpforcreatebutton['minutes']; $urltocreateaction .= '&backtopage='.urlencode($_SERVER["PHP_SELF"] . $newparam); $newcardbutton .= dolGetButtonTitle($langs->trans("AddAction"), '', 'fa fa-plus-circle', $urltocreateaction); } // Define the legend/list of calendard to show $s = ''; $link = ''; $showextcals = $listofextcals; $bookcalcalendars = array(); // Load Bookcal Calendars if (isModEnabled("bookcal")) { $sql = "SELECT ba.rowid, bc.label, bc.ref, bc.rowid as id_cal"; $sql .= " FROM ".MAIN_DB_PREFIX."bookcal_availabilities as ba"; $sql .= " JOIN ".MAIN_DB_PREFIX."bookcal_calendar as bc"; $sql .= " ON bc.rowid = ba.fk_bookcal_calendar"; $sql .= " WHERE bc.status = 1"; $sql .= " AND ba.status = 1"; $sql .= " AND bc.entity IN (".getEntity('agenda').")"; // bookcal is a "virtual view" of agenda if (!empty($filtert) && $filtert != '-1') { $sql .= " AND bc.visibility IN (".$db->sanitize($filtert, 0, 0, 0, 0).")"; } $resql = $db->query($sql); if ($resql) { $num = $db->num_rows($resql); $i = 0; while ($i < $num) { $objp = $db->fetch_object($resql); $label = !empty($objp->label) ? $objp->label : $objp->ref; $bookcalcalendars["calendars"][] = array("id" => $objp->id_cal, "label" => $label); $bookcalcalendars["availabilitieslink"][$objp->rowid] = $objp->id_cal; $i++; } } else { dol_print_error($db); } } if (!empty($conf->use_javascript_ajax)) { // If javascript on $s .= "\n".''."\n"; $s .= ''."\n"; // Local calendar $s .= '
'; // Holiday calendar if ($user->hasRight("holiday", "read")) { $s .= '
 
'; } // External calendars if (count($showextcals) > 0) { foreach ($showextcals as $val) { $htmlname = md5($val['name']); // not used for security purpose, only to get a string with no special char $s .= ''."\n"; $s .= '
'.$val ['name'].'  
'; } } // Birthdays //$s.='
'.$langs->trans("AgendaShowBirthdayEvents").'  
'; // Bookcal Calendar /* if (isModEnabled("bookcal")) { if (!empty($bookcalcalendars["calendars"])) { foreach ($bookcalcalendars["calendars"] as $key => $value) { $label = $value['label']; $s .= '
'; $s .= ''; $s .= '  
'; } } } */ // Calendars from hooks $parameters = array(); $reshook = $hookmanager->executeHooks('addCalendarChoice', $parameters, $object, $action); if (empty($reshook)) { $s .= $hookmanager->resPrint; } elseif ($reshook > 1) { $s = $hookmanager->resPrint; } $s .= "\n".''."\n"; } else { // If javascript off $newparam = $param; // newparam is for birthday links $newparam = preg_replace('/showbirthday=[0-1]/i', 'showbirthday='.(empty($showbirthday) ? 1 : 0), $newparam); if (!preg_match('/showbirthday=/i', $newparam)) { $newparam .= '&showbirthday=1'; } $link = ''; if (empty($showbirthday)) { $link .= $langs->trans("AgendaShowBirthdayEvents"); } else { $link .= $langs->trans("AgendaHideBirthdayEvents"); } $link .= ''; } // Load events from database into $eventarray $eventarray = array(); // DEFAULT CALENDAR + AUTOEVENT CALENDAR + CONFERENCEBOOTH CALENDAR $sql = "SELECT"; if ($usergroup > 0) { $sql .= " DISTINCT"; } $sql .= " a.id, a.label,"; $sql .= " a.datep,"; $sql .= " a.datep2,"; $sql .= " a.percent,"; $sql .= " a.fk_user_author,a.fk_user_action,"; $sql .= " a.transparency, a.priority, a.fulldayevent, a.location,"; $sql .= " a.fk_soc, a.fk_contact, a.fk_project, a.fk_bookcal_calendar,"; $sql .= " a.fk_element, a.elementtype,"; $sql .= " ca.code as type_code, ca.libelle as type_label, ca.color as type_color, ca.type as type_type, ca.picto as type_picto"; $parameters = array(); $reshook = $hookmanager->executeHooks('printFieldListSelect', $parameters); // Note that $action and $object may have been modified by hook $sql .= $hookmanager->resPrint; $sql .= " FROM ".MAIN_DB_PREFIX."c_actioncomm as ca, ".MAIN_DB_PREFIX."actioncomm as a"; // We must filter on resource table if ($resourceid > 0) { $sql .= ", ".MAIN_DB_PREFIX."element_resources as r"; } // We must filter on assignment table if ($filtert > 0 || $usergroup > 0) { $sql .= " INNER JOIN ".MAIN_DB_PREFIX."actioncomm_resources as ar"; $sql .= " ON ar.fk_actioncomm = a.id AND ar.element_type='user'"; if ($filtert > 0) { $sql .= " AND ar.fk_element = ".((int) $filtert); } if ($usergroup > 0) { $sql .= " INNER JOIN ".MAIN_DB_PREFIX."usergroup_user as ugu ON ugu.fk_user = ar.fk_element AND ugu.fk_usergroup = ".((int) $usergroup); } } $sql .= " WHERE a.fk_action = ca.id"; $sql .= " AND a.entity IN (".getEntity('agenda').")"; // bookcal is a "virtual view" of agenda // Condition on actioncode if (!empty($actioncode)) { if (!getDolGlobalString('AGENDA_USE_EVENT_TYPE')) { if ($actioncode == 'AC_NON_AUTO') { $sql .= " AND ca.type != 'systemauto'"; } elseif ($actioncode == 'AC_ALL_AUTO') { $sql .= " AND ca.type = 'systemauto'"; } else { if ($actioncode == 'AC_OTH') { $sql .= " AND ca.type != 'systemauto'"; } if ($actioncode == 'AC_OTH_AUTO') { $sql .= " AND ca.type = 'systemauto'"; } } } else { if ($actioncode == 'AC_NON_AUTO') { $sql .= " AND ca.type != 'systemauto'"; } elseif ($actioncode == 'AC_ALL_AUTO') { $sql .= " AND ca.type = 'systemauto'"; } elseif (/* !empty($actioncode) && */ $actioncode !== '-1') { if (is_array($actioncode)) { $sql .= " AND ca.code IN (".$db->sanitize("'".implode("','", $actioncode)."'", 1).")"; } else { $sql .= " AND ca.code IN (".$db->sanitize("'".implode("','", explode(',', $actioncode))."'", 1).")"; } } } } if ($resourceid > 0) { $sql .= " AND r.element_type = 'action' AND r.element_id = a.id AND r.resource_id = ".((int) $resourceid); } if ($pid) { $sql .= " AND a.fk_project = ".((int) $pid); } // If the internal user must only see his customers, force searching by him $search_sale = 0; if (isModEnabled("societe") && !$user->hasRight('societe', 'client', 'voir')) { $search_sale = $user->id; } // Search on sale representative if ($search_sale && $search_sale != '-1') { if ($search_sale == -2) { $sql .= " AND NOT EXISTS (SELECT sc.fk_soc FROM ".MAIN_DB_PREFIX."societe_commerciaux as sc WHERE sc.fk_soc = a.fk_soc)"; } elseif ($search_sale > 0) { $sql .= " AND EXISTS (SELECT sc.fk_soc FROM ".MAIN_DB_PREFIX."societe_commerciaux as sc WHERE sc.fk_soc = a.fk_soc AND sc.fk_user = ".((int) $search_sale).")"; } } // Search on socid if ($socid) { $sql .= " AND a.fk_soc = ".((int) $socid); } if ($mode == 'show_day') { $sql .= " AND ("; $sql .= " (a.datep BETWEEN '".$db->idate(dol_mktime(0, 0, 0, $month, $day, $year, 'tzuserrel'))."'"; $sql .= " AND '".$db->idate(dol_mktime(23, 59, 59, $month, $day, $year, 'tzuserrel'))."')"; $sql .= " OR "; $sql .= " (a.datep2 BETWEEN '".$db->idate(dol_mktime(0, 0, 0, $month, $day, $year, 'tzuserrel'))."'"; $sql .= " AND '".$db->idate(dol_mktime(23, 59, 59, $month, $day, $year, 'tzuserrel'))."')"; $sql .= " OR "; $sql .= " (a.datep < '".$db->idate(dol_mktime(0, 0, 0, $month, $day, $year, 'tzuserrel'))."'"; $sql .= " AND a.datep2 > '".$db->idate(dol_mktime(23, 59, 59, $month, $day, $year, 'tzuserrel'))."')"; $sql .= ")"; } else { // To limit array $sql .= " AND ("; $sql .= " (a.datep BETWEEN '".$db->idate($firstdaytoshow - (60 * 60 * 24 * 2))."'"; // Start 2 day before $firstdaytoshow $sql .= " AND '".$db->idate($lastdaytoshow + (60 * 60 * 24 * 2))."')"; // End 2 day after $lastdaytoshow $sql .= " OR "; $sql .= " (a.datep2 BETWEEN '".$db->idate($firstdaytoshow - (60 * 60 * 24 * 2))."'"; $sql .= " AND '".$db->idate($lastdaytoshow + (60 * 60 * 24 * 2))."')"; $sql .= " OR "; $sql .= " (a.datep < '".$db->idate($firstdaytoshow - (60 * 60 * 24 * 2))."'"; $sql .= " AND a.datep2 > '".$db->idate($lastdaytoshow + (60 * 60 * 24 * 2))."')"; $sql .= ")"; } if ($type) { $sql .= " AND ca.id = ".((int) $type); } if ($status == '0') { // To do (not started) $sql .= " AND a.percent = 0"; } if ($status === 'na') { // Not applicable $sql .= " AND a.percent = -1"; } if ($status == '50') { // Running already started $sql .= " AND (a.percent > 0 AND a.percent < 100)"; } if ($status == 'done' || $status == '100') { $sql .= " AND (a.percent = 100)"; } if ($status == 'todo') { $sql .= " AND (a.percent >= 0 AND a.percent < 100)"; } // We must filter on assignment table if ($filtert > 0 || $usergroup > 0) { $sql .= " AND ("; if ($filtert > 0) { $sql .= "ar.fk_element = ".((int) $filtert); } if ($usergroup > 0) { $sql .= ($filtert > 0 ? " OR " : "")." ugu.fk_usergroup = ".((int) $usergroup); } $sql .= ")"; } // Search in categories, -1 is all and -2 is no categories if ($search_categ_cus != -1) { if ($search_categ_cus == -2) { $sql .= " AND NOT EXISTS (SELECT ca.fk_actioncomm FROM ".MAIN_DB_PREFIX."categorie_actioncomm as ca WHERE ca.fk_actioncomm = a.id)"; } elseif ($search_categ_cus > 0) { $sql .= " AND EXISTS (SELECT ca.fk_actioncomm FROM ".MAIN_DB_PREFIX."categorie_actioncomm as ca WHERE ca.fk_actioncomm = a.id AND ca.fk_categorie IN (".$db->sanitize($search_categ_cus)."))"; } } // Sort on date $sql .= $db->order("fk_user_action, datep"); //print $sql; dol_syslog("comm/action/peruser.php", LOG_DEBUG); $resql = $db->query($sql); if ($resql) { $num = $db->num_rows($resql); $MAXONSAMEPAGE = 10000; // Useless to have more. Protection to avoid memory overload when high number of event (for example after a mass import) $i = 0; while ($i < $num && $i < $MAXONSAMEPAGE) { $obj = $db->fetch_object($resql); //print $obj->fk_user_action.' '.$obj->id."
"; // Discard auto action if option is on if (getDolGlobalString('AGENDA_ALWAYS_HIDE_AUTO') && $obj->type_code == 'AC_OTH_AUTO') { $i++; continue; } $datep = $db->jdate($obj->datep); $datep2 = $db->jdate($obj->datep2); // Create a new object action $event = new ActionComm($db); $event->id = $obj->id; $event->ref = (string) $event->id; $event->fulldayevent = $obj->fulldayevent; // event->datep and event->datef must be GMT date. if ($event->fulldayevent) { $tzforfullday = getDolGlobalString('MAIN_STORE_FULL_EVENT_IN_GMT'); $event->datep = $db->jdate($obj->datep, $tzforfullday ? 'tzuser' : 'tzserver'); // If saved in $tzforfullday = gmt, we must invert date to be in user tz $event->datef = $db->jdate($obj->datep2, $tzforfullday ? 'tzuser' : 'tzserver'); } else { // Example: $obj->datep = '1970-01-01 01:00:00', jdate will return 0 if TZ of PHP server is Europe/Berlin (+1) $event->datep = $db->jdate($obj->datep, 'tzserver'); $event->datef = $db->jdate($obj->datep2, 'tzserver'); } //$event->datep_formated_gmt = dol_print_date($event->datep, 'dayhour', 'gmt'); //var_dump($obj->id.' '.$obj->datep.' '.dol_print_date($obj->datep, 'dayhour', 'gmt')); //var_dump($obj->id.' '.$event->datep.' '.dol_print_date($event->datep, 'dayhour', 'gmt')); $event->type_code = $obj->type_code; $event->type_label = $obj->type_label; $event->type_color = $obj->type_color; $event->type = $obj->type_type; $event->type_picto = $obj->type_picto; $event->label = $obj->label; $event->percentage = $obj->percent; $event->authorid = $obj->fk_user_author; // user id of creator $event->userownerid = $obj->fk_user_action; // user id of owner $event->fetch_userassigned(); // This load $event->userassigned $event->priority = $obj->priority; $event->location = $obj->location; $event->transparency = $obj->transparency; $event->fk_element = $obj->fk_element; $event->elementid = $obj->fk_element; $event->elementtype = $obj->elementtype; $event->fk_project = $obj->fk_project; $event->socid = $obj->fk_soc; $event->contact_id = $obj->fk_contact; $event->fk_bookcal_calendar = $obj->fk_bookcal_calendar; if (!empty($event->fk_bookcal_calendar)) { $event->type = "bookcal_calendar"; } // Defined date_start_in_calendar and date_end_in_calendar property // They are date start and end of action but modified to not be outside calendar view. $event->date_start_in_calendar = $event->datep; if ($event->datef != '' && $event->datef >= $event->datep) { $event->date_end_in_calendar = $event->datef; } else { $event->date_end_in_calendar = $event->datep; } //print '
'.$i.' - eventid='.$event->id.' '.dol_print_date($event->date_start_in_calendar, 'dayhour').' '.dol_print_date($firstdaytoshow, 'dayhour').' - '.dol_print_date($event->date_end_in_calendar, 'dayhour').' '.dol_print_date($lastdaytoshow, 'dayhour').'
'."\n"; // Check values if ($event->date_end_in_calendar < $firstdaytoshow || $event->date_start_in_calendar >= $lastdaytoshow) { // This record is out of visible range unset($event); } else { if ($event->date_start_in_calendar < $firstdaytoshow) { $event->date_start_in_calendar = $firstdaytoshow; } if ($event->date_end_in_calendar >= $lastdaytoshow) { $event->date_end_in_calendar = ($lastdaytoshow - 1); } // Add an entry in actionarray for each day $daycursor = $event->date_start_in_calendar; $annee = (int) dol_print_date($daycursor, '%Y', 'tzuserrel'); $mois = (int) dol_print_date($daycursor, '%m', 'tzuserrel'); $jour = (int) dol_print_date($daycursor, '%d', 'tzuserrel'); $daycursorend = $event->date_end_in_calendar; $anneeend = (int) dol_print_date($daycursorend, '%Y', 'tzuserrel'); $moisend = (int) dol_print_date($daycursorend, '%m', 'tzuserrel'); $jourend = (int) dol_print_date($daycursorend, '%d', 'tzuserrel'); // Loop on each day covered by action to prepare an index to show on calendar $loop = true; $j = 0; $daykey = dol_mktime(0, 0, 0, $mois, $jour, $annee, 'gmt'); // $mois, $jour, $annee has been set for user tz $daykeyend = dol_mktime(0, 0, 0, $moisend, $jourend, $anneeend, 'gmt'); // $moisend, $jourend, $anneeend has been set for user tz /* print 'GMT '.$event->date_start_in_calendar.' '.dol_print_date($event->date_start_in_calendar, 'dayhour', 'gmt').'
'; print 'TZSERVER '.$event->date_start_in_calendar.' '.dol_print_date($event->date_start_in_calendar, 'dayhour', 'tzserver').'
'; print 'TZUSERREL '.$event->date_start_in_calendar.' '.dol_print_date($event->date_start_in_calendar, 'dayhour', 'tzuserrel').'
'; print 'GMT '.$event->date_end_in_calendar.' '.dol_print_date($event->date_end_in_calendar, 'dayhour', 'gmt').'
'; print 'TZSERVER '.$event->date_end_in_calendar.' '.dol_print_date($event->date_end_in_calendar, 'dayhour', 'tzserver').'
'; print 'TZUSER '.$event->date_end_in_calendar.' '.dol_print_date($event->date_end_in_calendar, 'dayhour', 'tzuserrel').'
'; */ do { //if ($event->id==408) //print 'daykey='.$daykey.' daykeyend='.$daykeyend.' '.dol_print_date($daykey, 'dayhour', 'gmt').' - '.dol_print_date($event->datep, 'dayhour', 'gmt').' '.dol_print_date($event->datef, 'dayhour', 'gmt').'
'; //print 'daykey='.$daykey.' daykeyend='.$daykeyend.' '.dol_print_date($daykey, 'dayhour', 'tzuserrel').' - '.dol_print_date($event->datep, 'dayhour', 'tzuserrel').' '.dol_print_date($event->datef, 'dayhour', 'tzuserrel').'
'; $eventarray[$daykey][] = $event; $j++; $daykey += 60 * 60 * 24; //if ($daykey > $event->date_end_in_calendar) { if ($daykey > $daykeyend) { $loop = false; } } while ($loop); //var_dump($eventarray); //print 'Event '.$i.' id='.$event->id.' (start='.dol_print_date($event->datep).'-end='.dol_print_date($event->datef); //print ' startincalendar='.dol_print_date($event->date_start_in_calendar).'-endincalendar='.dol_print_date($event->date_end_in_calendar).') was added in '.$j.' different index key of array
'; } $parameters['obj'] = $obj; $reshook = $hookmanager->executeHooks('hookEventElements', $parameters, $event, $action); // Note that $action and $object may have been modified by some hooks $event = $hookmanager->resPrint; if ($reshook < 0) { setEventMessages($hookmanager->error, $hookmanager->errors, 'errors'); } $i++; } $db->free($resql); } else { dol_print_error($db); } //var_dump($eventarray); // BIRTHDATES CALENDAR // Complete $eventarray with birthdates if ($showbirthday) { // Add events in array $sql = 'SELECT sp.rowid, sp.lastname, sp.firstname, sp.birthday'; $sql .= ' FROM '.MAIN_DB_PREFIX.'socpeople as sp'; $sql .= ' WHERE (priv=0 OR (priv=1 AND fk_user_creat='.((int) $user->id).'))'; $sql .= " AND sp.entity IN (".getEntity('contact').")"; if ($mode == 'show_day') { $sql .= ' AND MONTH(birthday) = '.((int) $month); $sql .= ' AND DAY(birthday) = '.((int) $day); } else { $sql .= ' AND MONTH(birthday) = '.((int) $month); } $sql .= ' ORDER BY birthday'; dol_syslog("comm/action/index.php", LOG_DEBUG); $resql = $db->query($sql); if ($resql) { $num = $db->num_rows($resql); $i = 0; while ($i < $num) { $obj = $db->fetch_object($resql); $event = new ActionComm($db); $event->id = $obj->rowid; // We put contact id in action id for birthdays events $event->ref = (string) $event->id; $datebirth = dol_stringtotime($obj->birthday, 1); //print 'ee'.$obj->birthday.'-'.$datebirth; $datearray = dol_getdate($datebirth, true); $event->datep = dol_mktime(0, 0, 0, $datearray['mon'], $datearray['mday'], $year, true); // For full day events, date are also GMT but they won't but converted during output $event->datef = $event->datep; $event->type_code = 'BIRTHDAY'; $event->type_label = ''; $event->type_color = ''; $event->type = 'birthdate'; $event->type_picto = 'birthdate'; $event->label = $langs->trans("Birthday").' '.dolGetFirstLastname($obj->firstname, $obj->lastname); $event->percentage = 100; $event->fulldayevent = 1; $event->contact_id = $obj->rowid; $event->date_start_in_calendar = $db->jdate($event->datep); $event->date_end_in_calendar = $db->jdate($event->datef); // Add an entry in eventarray for each day $daycursor = $event->datep; $annee = (int) dol_print_date($daycursor, '%Y', 'tzuserrel'); $mois = (int) dol_print_date($daycursor, '%m', 'tzuserrel'); $jour = (int) dol_print_date($daycursor, '%d', 'tzuserrel'); $daykey = dol_mktime(0, 0, 0, $mois, $jour, $annee, 'gmt'); $eventarray[$daykey][] = $event; /*$loop = true; $daykey = dol_mktime(0, 0, 0, $mois, $jour, $annee); do { $eventarray[$daykey][] = $event; $daykey += 60 * 60 * 24; if ($daykey > $event->date_end_in_calendar) $loop = false; } while ($loop); */ $i++; } } else { dol_print_error($db); } } if ($user->hasRight("holiday", "read")) { // LEAVE-HOLIDAY CALENDAR $sql = "SELECT u.rowid as uid, u.lastname, u.firstname, u.statut, x.rowid, x.date_debut as date_start, x.date_fin as date_end, x.halfday, x.statut as status"; $sql .= " FROM ".MAIN_DB_PREFIX."holiday as x, ".MAIN_DB_PREFIX."user as u"; $sql .= " WHERE u.rowid = x.fk_user"; $sql .= " AND u.statut = '1'"; // Show only active users (0 = inactive user, 1 = active user) $sql .= " AND (x.statut = '2' OR x.statut = '3')"; // Show only public leaves (2 = leave wait for approval, 3 = leave approved) // Restrict on current month (we get more, but we will filter later) $sql .= " AND x.date_debut < '".$db->idate(dol_get_last_day($year, $month))."'"; $sql .= " AND x.date_fin >= '".$db->idate(dol_get_first_day($year, $month))."'"; if (!$user->hasRight('holiday', 'readall')) { $sql.= " AND x.fk_user IN(".$db->sanitize(implode(", ", $user->getAllChildIds(1))).") "; } $resql = $db->query($sql); if ($resql) { $num = $db->num_rows($resql); $i = 0; while ($i < $num) { $obj = $db->fetch_object($resql); $event = new ActionComm($db); // Need the id of the leave object for link to it $event->id = $obj->rowid; $event->ref = (string) $event->id; $event->type_code = 'HOLIDAY'; $event->type_label = ''; $event->type_color = ''; $event->type = 'holiday'; $event->type_picto = 'holiday'; $event->datep = $db->jdate($obj->date_start) + (empty($obj->halfday) || $obj->halfday == 1 ? 0 : 12) * 60 * 60; $event->datef = $db->jdate($obj->date_end) + (empty($obj->halfday) || $obj->halfday == -1 ? 24 : 12) * 60 * 60 - 1; $event->date_start_in_calendar = $event->datep; $event->date_end_in_calendar = $event->datef; $event->transparency = 1; $event->userownerid = $obj->uid; // user id of owner $event->userassigned = array($obj->uid => array('id' => $obj->uid, 'transparency' => 1)); if ($obj->status == 3) { // Show no symbol for leave with state "leave approved" $event->percentage = -1; } elseif ($obj->status == 2) { // Show TO-DO symbol for leave with state "leave wait for approval" $event->percentage = 0; } $daycursor = $event->date_start_in_calendar; $annee = (int) dol_print_date($daycursor, '%Y', 'tzuserrel'); $mois = (int) dol_print_date($daycursor, '%m', 'tzuserrel'); $jour = (int) dol_print_date($daycursor, '%d', 'tzuserrel'); $daycursorend = $event->date_end_in_calendar; $anneeend = (int) dol_print_date($daycursorend, '%Y', 'tzuserrel'); $moisend = (int) dol_print_date($daycursorend, '%m', 'tzuserrel'); $jourend = (int) dol_print_date($daycursorend, '%d', 'tzuserrel'); // daykey must be date that represent day box in calendar so must be a user time $daykey = dol_mktime(0, 0, 0, $mois, $jour, $annee, 'gmt'); $daykeygmt = dol_mktime(0, 0, 0, $mois, $jour, $annee, 'gmt'); $ifornbofdays = 0; do { $ifornbofdays++; $firstdayofholiday = ($ifornbofdays == 1); $lastdayofholiday = ($daykeygmt == dol_get_first_hour($event->date_end_in_calendar, 'gmt')); //var_dump(dol_print_date($daykeygmt, 'dayhour', 'gmt')); if ((in_array($obj->halfday, array(1, 2)) == 1 && $lastdayofholiday) || (in_array($obj->halfday, array(-1, 2)) && $firstdayofholiday)) { // We create a copy of event because we want tochange the label $newevent = dol_clone($event, 1); if (in_array($obj->halfday, array(1, 2)) && $lastdayofholiday) { $newevent->label .= ' ('.$langs->trans("Morning").')'; } elseif (in_array($obj->halfday, array(-1, 2)) && $firstdayofholiday) { $newevent->label .= ' ('.$langs->trans("Afternoon").')'; } $eventarray[$daykey][] = $newevent; // We need to use ->gtTypePicto, getXXXon object, so clone must be PHP clone. } else { $eventarray[$daykey][] = $event; // We can use the event unchanged } $daykey += 60 * 60 * 24; $daykeygmt += 60 * 60 * 24; } while ($daykey <= $event->date_end_in_calendar); $i++; } } } // EXTERNAL CALENDAR // Complete $eventarray with external import Ical if (count($listofextcals)) { require_once DOL_DOCUMENT_ROOT.'/comm/action/class/ical.class.php'; foreach ($listofextcals as $key => $extcal) { $url = $extcal['src']; // Example: https://www.google.com/calendar/ical/eldy10%40gmail.com/private-cde92aa7d7e0ef6110010a821a2aaeb/basic.ics $namecal = $extcal['name']; $offsettz = $extcal['offsettz']; $colorcal = $extcal['color']; $buggedfile = $extcal['buggedfile']; $pathforcachefile = dol_sanitizePathName($conf->user->dir_temp).'/'.dol_sanitizeFileName('extcal_'.$namecal.'_user'.$user->id).'.cache'; //var_dump($pathforcachefile);exit; $ical = new ICal(); $ical->parse($url, $pathforcachefile, $DELAYFORCACHE); if ($ical->error) { // Save error message for extcal $listofextcals[$key]['error'] = $ical->error; $s .= '
'.dol_escape_htmltag($listofextcals[$key]['name']).': '.$url.'
Error message: '.dol_escape_htmltag($ical->error).'
'; } // After this $ical->cal['VEVENT'] contains array of events, $ical->cal['DAYLIGHT'] contains daylight info, $ical->cal['STANDARD'] contains non daylight info, ... //var_dump($ical->cal); exit; $icalevents = array(); if (is_array($ical->get_event_list())) { $icalevents = array_merge($icalevents, $ical->get_event_list()); // Add $ical->cal['VEVENT'] } if (is_array($ical->get_freebusy_list())) { $icalevents = array_merge($icalevents, $ical->get_freebusy_list()); // Add $ical->cal['VFREEBUSY'] } if (count($icalevents) > 0) { // Duplicate all repeatable events into new entries $moreicalevents = array(); foreach ($icalevents as $icalevent) { if (isset($icalevent['RRULE']) && is_array($icalevent['RRULE'])) { //repeatable event //if ($event->date_start_in_calendar < $firstdaytoshow) $event->date_start_in_calendar=$firstdaytoshow; //if ($event->date_end_in_calendar > $lastdaytoshow) $event->date_end_in_calendar=($lastdaytoshow-1); if ($icalevent['DTSTART;VALUE=DATE']) { //fullday event $datecurstart = dol_stringtotime($icalevent['DTSTART;VALUE=DATE'], 1); $datecurend = dol_stringtotime($icalevent['DTEND;VALUE=DATE'], 1) - 1; // We remove one second to get last second of day } elseif (is_array($icalevent['DTSTART']) && !empty($icalevent['DTSTART']['unixtime'])) { $datecurstart = $icalevent['DTSTART']['unixtime']; // can't be empty $datecurend = $icalevent['DTEND']['unixtime']; if (!empty($ical->cal['DAYLIGHT']['DTSTART']) /* && $datecurstart */) { //var_dump($ical->cal); $tmpcurstart = $datecurstart; $tmpcurend = $datecurend; $tmpdaylightstart = dol_mktime(0, 0, 0, 1, 1, 1970, 1) + (int) $ical->cal['DAYLIGHT']['DTSTART']; $tmpdaylightend = dol_mktime(0, 0, 0, 1, 1, 1970, 1) + (int) $ical->cal['STANDARD']['DTSTART']; //var_dump($tmpcurstart);var_dump($tmpcurend); var_dump($ical->cal['DAYLIGHT']['DTSTART']);var_dump($ical->cal['STANDARD']['DTSTART']); // Edit datecurstart and datecurend if ($tmpcurstart >= $tmpdaylightstart && $tmpcurstart < $tmpdaylightend) { $datecurstart -= ((int) $ical->cal['DAYLIGHT']['TZOFFSETTO']) * 36; } else { $datecurstart -= ((int) $ical->cal['STANDARD']['TZOFFSETTO']) * 36; } if ($tmpcurend >= $tmpdaylightstart && $tmpcurstart < $tmpdaylightend) { $datecurend -= ((int) $ical->cal['DAYLIGHT']['TZOFFSETTO']) * 36; } else { $datecurend -= ((int) $ical->cal['STANDARD']['TZOFFSETTO']) * 36; } } // datecurstart and datecurend are now GMT date //var_dump($datecurstart); var_dump($datecurend); exit; } else { // Not a recognized record dol_syslog("Found a not recognized repeatable record with unknown date start", LOG_ERR); continue; } //print 'xx'.$datecurstart;exit; $interval = (empty($icalevent['RRULE']['INTERVAL']) ? 1 : $icalevent['RRULE']['INTERVAL']); $until = empty($icalevent['RRULE']['UNTIL']) ? 0 : dol_stringtotime($icalevent['RRULE']['UNTIL'], 1); $maxrepeat = empty($icalevent['RRULE']['COUNT']) ? 0 : $icalevent['RRULE']['COUNT']; if ($until && ($until + ($datecurend - $datecurstart)) < $firstdaytoshow) { continue; // We discard repeatable event that end before start date to show } if ($datecurstart >= $lastdaytoshow) { continue; // We discard repeatable event that start after end date to show } $numofevent = 0; while (($datecurstart < $lastdaytoshow) && (empty($maxrepeat) || ($numofevent < $maxrepeat))) { if ($datecurend >= $firstdaytoshow) { // We add event $newevent = $icalevent; unset($newevent['RRULE']); if ($icalevent['DTSTART;VALUE=DATE']) { $newevent['DTSTART;VALUE=DATE'] = dol_print_date($datecurstart, '%Y%m%d'); $newevent['DTEND;VALUE=DATE'] = dol_print_date($datecurend + 1, '%Y%m%d'); } else { $newevent['DTSTART'] = $datecurstart; $newevent['DTEND'] = $datecurend; } $moreicalevents[] = $newevent; } // Jump on next occurrence $numofevent++; $savdatecurstart = $datecurstart; if ($icalevent['RRULE']['FREQ'] == 'DAILY') { $datecurstart = dol_time_plus_duree($datecurstart, $interval, 'd'); $datecurend = dol_time_plus_duree($datecurend, $interval, 'd'); } if ($icalevent['RRULE']['FREQ'] == 'WEEKLY') { $datecurstart = dol_time_plus_duree($datecurstart, $interval, 'w'); $datecurend = dol_time_plus_duree($datecurend, $interval, 'w'); } elseif ($icalevent['RRULE']['FREQ'] == 'MONTHLY') { $datecurstart = dol_time_plus_duree($datecurstart, $interval, 'm'); $datecurend = dol_time_plus_duree($datecurend, $interval, 'm'); } elseif ($icalevent['RRULE']['FREQ'] == 'YEARLY') { $datecurstart = dol_time_plus_duree($datecurstart, $interval, 'y'); $datecurend = dol_time_plus_duree($datecurend, $interval, 'y'); } // Test to avoid infinite loop ($datecurstart must increase) if ($savdatecurstart >= $datecurstart) { dol_syslog("Found a rule freq ".$icalevent['RRULE']['FREQ']." not managed by dolibarr code. Assume 1 week frequency.", LOG_ERR); $datecurstart += 3600 * 24 * 7; $datecurend += 3600 * 24 * 7; } } } } $icalevents = array_merge($icalevents, $moreicalevents); // Loop on each entry into cal file to know if entry is qualified and add an ActionComm into $eventarray foreach ($icalevents as $icalevent) { //var_dump($icalevent); //print $icalevent['SUMMARY'].'->'; //var_dump($icalevent);exit; if (!empty($icalevent['RRULE'])) { continue; // We found a repeatable event. It was already split into unitary events, so we discard general rule. } // Create a new object action $event = new ActionComm($db); $addevent = false; $datestart = null; $dateend = null; if (isset($icalevent['DTSTART;VALUE=DATE'])) { // fullday event // For full day events, date are also GMT but they won't but converted using tz during output $datestart = dol_stringtotime($icalevent['DTSTART;VALUE=DATE'], 1); if (empty($icalevent['DTEND;VALUE=DATE'])) { $dateend = $datestart + 86400 - 1; } else { $dateend = dol_stringtotime($icalevent['DTEND;VALUE=DATE'], 1) - 1; // We remove one second to get last second of day } //print 'x'.$datestart.'-'.$dateend;exit; //print dol_print_date($dateend,'dayhour','gmt'); $event->fulldayevent = 1; $addevent = true; } elseif (!is_array($icalevent['DTSTART'])) { // not fullday event (DTSTART is not array. It is a value like '19700101T000000Z' for 00:00 in greenwitch) $datestart = $icalevent['DTSTART']; $dateend = empty($icalevent['DTEND']) ? $datestart : $icalevent['DTEND']; $datestart += +($offsettz * 3600); $dateend += +($offsettz * 3600); $addevent = true; //var_dump($offsettz); //var_dump(dol_print_date($datestart, 'dayhour', 'gmt')); } elseif (isset($icalevent['DTSTART']['unixtime'])) { // File contains a local timezone + a TZ (for example when using bluemind) $datestart = $icalevent['DTSTART']['unixtime']; $dateend = $icalevent['DTEND']['unixtime']; $datestart += +($offsettz * 3600); $dateend += +($offsettz * 3600); // $buggedfile is set to uselocalandtznodaylight if conf->global->AGENDA_EXT_BUGGEDFILEx = 'uselocalandtznodaylight' if ($buggedfile === 'uselocalandtznodaylight') { // unixtime is a local date that does not take daylight into account, TZID is +1 for example for 'Europe/Paris' in summer instead of 2 // TODO } // $buggedfile is set to uselocalandtzdaylight if conf->global->AGENDA_EXT_BUGGEDFILEx = 'uselocalandtzdaylight' (for example with bluemind) if ($buggedfile === 'uselocalandtzdaylight') { // unixtime is a local date that does take daylight into account, TZID is +2 for example for 'Europe/Paris' in summer $localtzs = new DateTimeZone(preg_replace('/"/', '', $icalevent['DTSTART']['TZID'])); $localtze = new DateTimeZone(preg_replace('/"/', '', $icalevent['DTEND']['TZID'])); $localdts = new DateTime(dol_print_date($datestart, 'dayrfc', 'gmt'), $localtzs); $localdte = new DateTime(dol_print_date($dateend, 'dayrfc', 'gmt'), $localtze); $tmps = -1 * $localtzs->getOffset($localdts); $tmpe = -1 * $localtze->getOffset($localdte); $datestart += $tmps; $dateend += $tmpe; //var_dump($datestart); } $addevent = true; } if ($addevent) { $event->id = $icalevent['UID']; $event->ref = (string) $event->id; $userstatic = new User($db); $userId = $userstatic->findUserIdByEmail($namecal); if (!empty($userId) && $userId > 0) { $event->userassigned[$userId] = [ 'id' => $userId, 'transparency' => 1, ]; $event->percentage = -1; } $event->type_code = "ICALEVENT"; $event->type_label = $namecal; $event->type_color = $colorcal; $event->type = 'icalevent'; $event->type_picto = 'rss'; $event->icalname = $namecal; $event->icalcolor = $colorcal; $usertime = 0; // We don't modify date because we want to have date into memory datep and datef stored as GMT date. Compensation will be done during output. $event->datep = $datestart + $usertime; $event->datef = $dateend + $usertime; if (isset($icalevent['SUMMARY']) && $icalevent['SUMMARY']) { $event->label = dol_string_nohtmltag($icalevent['SUMMARY']); } elseif (isset($icalevent['DESCRIPTION']) && $icalevent['DESCRIPTION']) { $event->label = dol_nl2br(dol_string_nohtmltag($icalevent['DESCRIPTION']), 1); } else { $event->label = $langs->trans("ExtSiteNoLabel"); } // Priority (see https://www.kanzaki.com/docs/ical/priority.html) // LOW = 0 to 4 // MEDIUM = 5 // HIGH = 6 to 9 if (!empty($icalevent['PRIORITY'])) { $event->priority = $icalevent['PRIORITY']; } // Transparency (see https://www.kanzaki.com/docs/ical/transp.html) if (!empty($icalevent['TRANSP'])) { if ($icalevent['TRANSP'] == "TRANSPARENT") { $event->transparency = 0; // 0 = available / free } if ($icalevent['TRANSP'] == "OPAQUE") { $event->transparency = 1; // 1 = busy } // TODO: MS outlook states // X-MICROSOFT-CDO-BUSYSTATUS:FREE + TRANSP:TRANSPARENT => Available / Free // X-MICROSOFT-CDO-BUSYSTATUS:FREE + TRANSP:OPAQUE => Work another place // X-MICROSOFT-CDO-BUSYSTATUS:TENTATIVE + TRANSP:OPAQUE => With reservations // X-MICROSOFT-CDO-BUSYSTATUS:BUSY + TRANSP:OPAQUE => Busy // X-MICROSOFT-CDO-BUSYSTATUS:OOF + TRANSP:OPAQUE => Away from the office / off-site } if (!empty($icalevent['LOCATION'])) { $event->location = $icalevent['LOCATION']; } $event->date_start_in_calendar = $event->datep; if ($event->datef != '' && $event->datef >= $event->datep) { $event->date_end_in_calendar = $event->datef; } else { $event->date_end_in_calendar = $event->datep; } // Add event into $eventarray if date range are ok. if ($event->date_end_in_calendar < $firstdaytoshow || $event->date_start_in_calendar >= $lastdaytoshow) { //print 'x'.$datestart.'-'.$dateend;exit; //print 'x'.$datestart.'-'.$dateend;exit; //print 'x'.$datestart.'-'.$dateend;exit; // This record is out of visible range } else { if ($event->date_start_in_calendar < $firstdaytoshow) { $event->date_start_in_calendar = $firstdaytoshow; } if ($event->date_end_in_calendar >= $lastdaytoshow) { $event->date_end_in_calendar = ($lastdaytoshow - 1); } // Add an entry in actionarray for each day $daycursor = $event->date_start_in_calendar; $annee = (int) dol_print_date($daycursor, '%Y', 'tzuserrel'); $mois = (int) dol_print_date($daycursor, '%m', 'tzuserrel'); $jour = (int) dol_print_date($daycursor, '%d', 'tzuserrel'); // Loop on each day covered by action to prepare an index to show on calendar $loop = true; $j = 0; // daykey must be date that represent day box in calendar so must be a user time $daykey = dol_mktime(0, 0, 0, $mois, $jour, $annee, 'gmt'); $daykeygmt = dol_mktime(0, 0, 0, $mois, $jour, $annee, 'gmt'); do { //if ($event->fulldayevent) print dol_print_date($daykeygmt,'dayhour','gmt').'-'.dol_print_date($daykey,'dayhour','gmt').'-'.dol_print_date($event->date_end_in_calendar,'dayhour','gmt').' '; $eventarray[$daykey][] = $event; $daykey += 60 * 60 * 24; $daykeygmt += 60 * 60 * 24; // Add one day if (($event->fulldayevent ? $daykeygmt : $daykey) > $event->date_end_in_calendar) { $loop = false; } } while ($loop); } } } } } } // Complete $eventarray with events coming from external module $parameters = array(); $object = null; $reshook = $hookmanager->executeHooks('getCalendarEvents', $parameters, $object, $action); if (!empty($hookmanager->resArray['eventarray'])) { foreach ($hookmanager->resArray['eventarray'] as $keyDate => $events) { if (!isset($eventarray[$keyDate])) { $eventarray[$keyDate] = array(); } $eventarray[$keyDate] = array_merge($eventarray[$keyDate], $events); } } // Sort events foreach ($eventarray as $keyDate => &$dateeventarray) { usort($dateeventarray, 'sort_events_by_date'); } $maxnbofchar = 18; $cachethirdparties = array(); $cachecontacts = array(); $cacheusers = array(); // Define theme_datacolor array $color_file = DOL_DOCUMENT_ROOT."/theme/".$conf->theme."/theme_vars.inc.php"; if (is_readable($color_file)) { include $color_file; } if (!is_array($theme_datacolor)) { $theme_datacolor = array(array(137, 86, 161), array(60, 147, 183), array(250, 190, 80), array(80, 166, 90), array(190, 190, 100), array(91, 115, 247), array(140, 140, 220), array(190, 120, 120), array(115, 125, 150), array(100, 170, 20), array(150, 135, 125), array(85, 135, 150), array(150, 135, 80), array(150, 80, 150)); } $massactionbutton = ''; $num = 0; print_barre_liste($langs->trans("Agenda"), $page, $_SERVER["PHP_SELF"], $param, $sortfield, $sortorder, $massactionbutton, $num, -1, 'object_action', 0, $nav.''.$newcardbutton, '', $limit, 1, 0, 1, $viewmode); $link = ''; // Show div with list of calendars print $s; print '
'; print_actions_filter($form, $canedit, $search_status, $year, $month, $day, $showbirthday, '', (string) $filtert, '', $pid, $socid, $action, -1, $actioncode, $usergroup, '', $resourceid, $search_categ_cus); print '
'; $newparam = $param; // newparam is for birthday links $newparam = preg_replace('/showbirthday=/i', 'showbirthday_=', $newparam); // To avoid replacement when replace day= is done $newparam = preg_replace('/mode=show_month&?/i', '', $newparam); $newparam = preg_replace('/mode=show_week&?/i', '', $newparam); $newparam = preg_replace('/day=[0-9]+&?/i', '', $newparam); $newparam = preg_replace('/month=[0-9]+&?/i', '', $newparam); $newparam = preg_replace('/year=[0-9]+&?/i', '', $newparam); $newparam = preg_replace('/viewweek=[0-9]+&?/i', '', $newparam); $newparam = preg_replace('/showbirthday_=/i', 'showbirthday=', $newparam); // Restore correct parameter $newparam .= '&viewweek=1'; echo ''; echo ''; echo ''; // Line header with list of days //print "begin_d=".$begin_d." end_d=".$end_d; $currentdaytoshow = $firstdaytoshow; echo '
'; //print dol_print_date($currentdaytoshow, 'dayhour', 'gmt'); $colorsbytype = array(); while ($currentdaytoshow < $lastdaytoshow) { echo ''; echo ''; echo ''; $i = 0; // 0 = sunday, while ($i < 7) { if (($i + 1) < $begin_d || ($i + 1) > $end_d) { $i++; continue; } echo '\n"; $i++; } echo "\n"; echo ''; echo ''; $i = 0; while ($i < 7) { if (($i + 1) < $begin_d || ($i + 1) > $end_d) { $i++; continue; } for ($h = $begin_h; $h < $end_h; $h++) { echo '"; } echo "\n"; $i++; } echo "\n"; // Define $usernames $usernames = array(); //init $usernamesid = array(); /* Use this to have list of users only if users have events */ if (getDolGlobalString('AGENDA_SHOWOWNERONLY_ONPERUSERVIEW')) { foreach ($eventarray as $daykey => $notused) { // Get all assigned users for each event foreach ($eventarray[$daykey] as $index => $event) { $event->fetch_userassigned(); $listofuserid = $event->userassigned; foreach ($listofuserid as $userid => $tmp) { if (!in_array($userid, $usernamesid)) { $usernamesid[$userid] = $userid; } } } } } else { /* Use this list to have lines for all users */ $sql = "SELECT u.rowid, u.lastname as lastname, u.firstname, u.statut, u.login, u.admin, u.entity"; $sql .= " FROM ".$db->prefix()."user as u"; if (isModEnabled('multicompany') && getDolGlobalInt('MULTICOMPANY_TRANSVERSE_MODE')) { $sql .= " WHERE u.rowid IN ("; $sql .= " SELECT ug.fk_user FROM ".$db->prefix()."usergroup_user as ug"; $sql .= " WHERE ug.entity IN (".getEntity('usergroup').")"; if ($usergroup > 0) { $sql .= " AND ug.fk_usergroup = ".((int) $usergroup); } $sql .= ")"; } else { if ($usergroup > 0) { $sql .= " LEFT JOIN ".$db->prefix()."usergroup_user as ug ON u.rowid = ug.fk_user"; } $sql .= " WHERE u.entity IN (".getEntity('user').")"; if ($usergroup > 0) { $sql .= " AND ug.fk_usergroup = ".((int) $usergroup); } } $sql .= " AND u.statut = 1"; if ($filtert > 0) { $sql .= " AND u.rowid = ".((int) $filtert); } if ($usergroup > 0) { $sql .= " AND ug.fk_usergroup = ".((int) $usergroup); } if ($user->socid > 0) { // External users should see only contacts of their company $sql .= " AND u.fk_soc = ".((int) $user->socid); } //print $sql; $resql = $db->query($sql); if ($resql) { $num = $db->num_rows($resql); $i = 0; if ($num) { while ($i < $num) { $obj = $db->fetch_object($resql); $usernamesid[$obj->rowid] = $obj->rowid; $i++; } } } else { dol_print_error($db); } } //var_dump($usernamesid); foreach ($usernamesid as $id) { $tmpuser = new User($db); $result = $tmpuser->fetch($id); $usernames[] = $tmpuser; } // Load array of colors by type $labelbytype = array(); $sql = "SELECT code, color, libelle as label FROM ".MAIN_DB_PREFIX."c_actioncomm ORDER BY position"; $resql = $db->query($sql); while ($obj = $db->fetch_object($resql)) { $colorsbytype[$obj->code] = $obj->color; $labelbytype[$obj->code] = $obj->label; } // Loop on each user to show calendar $todayarray = dol_getdate($now, true); $sav = $tmpday; $showheader = true; $var = false; foreach ($usernames as $username) { //if ($username->login != 'admin') continue; $var = !$var; echo ""; echo ''; $tmpday = $sav; // Lopp on each day of week $i = 0; for ($iter_day = 0; $iter_day < 8; $iter_day++) { if (($i + 1) < $begin_d || ($i + 1) > $end_d) { $i++; continue; } // Show days of the current week $curtime = dol_time_plus_duree($currentdaytoshow, $iter_day, 'd'); // $curtime is a gmt time, but we want the day, month, year in user TZ $tmpday = (int) dol_print_date($curtime, "%d", "tzuserrel"); $tmpmonth = (int) dol_print_date($curtime, "%m", "tzuserrel"); $tmpyear = (int) dol_print_date($curtime, "%Y", "tzuserrel"); //var_dump($curtime.' '.$tmpday.' '.$tmpmonth.' '.$tmpyear); $style = 'cal_current_month'; if ($iter_day == 6) { $style .= ' cal_other_month'; } $today = 0; if ($todayarray['mday'] == $tmpday && $todayarray['mon'] == $tmpmonth && $todayarray['year'] == $tmpyear) { $today = 1; } if ($today) { $style = 'cal_today_peruser'; } show_day_events2($username, $tmpday, $tmpmonth, $tmpyear, 0, $style, $eventarray, 0, $maxnbofchar, $newparam, 1, 300, $showheader, $colorsbytype, $var); $i++; } echo "\n"; $showheader = false; } echo "
'; if ($canedit /* && $mode == 'show_peruser' */) { // mode is forced to show_peruser // Filter on days print ''; print img_picto('', 'clock', 'class="fawidth30 inline-block marginleftonly"'); print $langs->trans("DaysOfWeek").''; print "\n"; print '
'; print ''; if (empty($conf->dol_use_jmobile)) { print ' - '; } else { print '
'; } print ''; print '
'; } print '
'; echo ''.$langs->trans("Day".(($i + (isset($conf->global->MAIN_START_WEEK) ? $conf->global->MAIN_START_WEEK : 1)) % 7)).''; print "
"; if ($i) { print dol_print_date(dol_time_plus_duree($currentdaytoshow, $i, 'd'), 'day', 'tzuserrel'); } else { print dol_print_date($currentdaytoshow, 'day', 'tzuserrel'); } echo "
'; // Filter on hours print ''; print img_picto('', 'clock', 'class="fawidth30 inline-block marginleftonly"'); print $langs->trans("Hours").''; print "\n"; print '
'; print ''; if (empty($conf->dol_use_jmobile)) { print ' - '; } else { print '
'; } print ''; if (empty($conf->dol_use_jmobile)) { print ' '.$langs->trans("H"); } print '
'; echo '
'; print ''.sprintf("%02d", $h).''; print "
'; print ''; print $username->getNomUrl(-1, '', 0, 0, 20, 1, '', 'paddingleft'); print ''; print '
\n"; echo "
"; $currentdaytoshow = dol_time_plus_duree($currentdaytoshow, 7, 'd'); } echo '
'; if (getDolGlobalString('AGENDA_USE_EVENT_TYPE') && getDolGlobalString('AGENDA_USE_COLOR_PER_EVENT_TYPE')) { $langs->load("commercial"); print '
'.$langs->trans("Legend").':
'; foreach ($colorsbytype as $code => $color) { if ($color) { print '
 
'; print $langs->trans("Action".$code) != "Action".$code ? $langs->trans("Action".$code) : $labelbytype[$code]; //print $code; print '
'; } } //$color=sprintf("%02x%02x%02x",$theme_datacolor[0][0],$theme_datacolor[0][1],$theme_datacolor[0][2]); print '
 
'; print $langs->trans("Other"); print '
'; /* TODO Show this if at least one cumulated event print '
 
'; print $langs->trans("SeveralEvents"); print '
'; */ } print "\n".'
'; print "\n"; // Add js code to manage click on a box print ''; // End of page llxFooter(); $db->close(); /** * Show event line of a particular day for a user * * @param User $username Login * @param int $day Day * @param int $month Month * @param int $year Year * @param int $monthshown Current month shown in calendar view * @param string $style Style to use for this day * @param array $eventarray Array of events * @param int $maxprint Nb of actions to show each day on month view (0 means no limit) * @param int $maxnbofchar Nb of characters to show for event line * @param string $newparam Parameters on current URL * @param int $showinfo Add extended information (used by day view) * @param int $minheight Minimum height for each event. 60px by default. * @param boolean $showheader Show header * @param array $colorsbytype Array with colors by type * @param bool $var true or false for alternat style on tr/td * @return void */ function show_day_events2($username, $day, $month, $year, $monthshown, $style, &$eventarray, $maxprint = 0, $maxnbofchar = 16, $newparam = '', $showinfo = 0, $minheight = 60, $showheader = false, $colorsbytype = array(), $var = false) { global $db; global $user, $conf, $langs, $hookmanager, $action; global $filter, $filtert, $status, $actioncode; // Filters used into search form global $theme_datacolor; // Array with a list of different we can use (come from theme) global $cachethirdparties, $cachecontacts, $cacheusers, $cacheprojects, $colorindexused; global $begin_h, $end_h; $cases1 = array(); // Color first half hour $cases2 = array(); // Color second half hour $cases3 = array(); // Color third half hour $cases4 = array(); // Color 4th half hour $i = 0; $numother = 0; $numbirthday = 0; $numical = 0; $numicals = array(); //$ymd = sprintf("%04d", $year).sprintf("%02d", $month).sprintf("%02d", $day); $colorindexused[$user->id] = 0; // Color index for current user (user->id) is always 0 $nextindextouse = count($colorindexused); // At first run this is 0, so first user has 0, next 1, ... //if ($username->id && $day==1) { //var_dump($eventarray); //} //var_dump("------ username=".$username->login." for day=".$day); // We are in a particular day for $username, now we scan all events foreach ($eventarray as $daykey => $notused) { $annee = (int) dol_print_date($daykey, '%Y', 'tzuserrel'); $mois = (int) dol_print_date($daykey, '%m', 'tzuserrel'); $jour = (int) dol_print_date($daykey, '%d', 'tzuserrel'); //var_dump("daykey=$daykey day=$day jour=$jour, month=$month mois=$mois, year=$year annee=$annee ".dol_print_date($daykey, 'dayhour', 'gmt')); //var_dump($notused); if ($day == $jour && (int) $month == $mois && $year == $annee) { // Is it the day we are looking for when calling function ? //var_dump("day=$day jour=$jour month=$month mois=$mois year=$year annee=$annee"); // Scan all event for this date foreach ($eventarray[$daykey] as $index => $event) { //print 'daykey='.$daykey.'='.dol_print_date($daykey, 'dayhour', 'gmt').' '.$year.'-'.$month.'-'.$day.' -> The event id '.$event->id.' index '.$index.' is open for this daykey '.$annee.'-'.$mois.'-'.$jour."
\n"; //var_dump($event); $keysofuserassigned = array_keys($event->userassigned); if (!in_array($username->id, $keysofuserassigned)) { continue; // We discard record if event is from another user than user we want to show } //if ($username->id != $event->userownerid) continue; // We discard record if event is from another user than user we want to show $parameters = array(); $reshook = $hookmanager->executeHooks('formatEvent', $parameters, $event, $action); // Note that $action and $object may have been modified by some hooks if ($reshook < 0) { setEventMessages($hookmanager->error, $hookmanager->errors, 'errors'); } // Define $color (Hex string like '0088FF') and $cssclass of event $color = -1; $cssclass = ''; $colorindex = -1; if ($event->type_code == 'HOLIDAY') { $cssclass = 'family_holiday'; } if (in_array($user->id, $keysofuserassigned)) { $cssclass = 'family_mytasks'; if (empty($cacheusers[$event->userownerid])) { $newuser = new User($db); $newuser->fetch($event->userownerid); $cacheusers[$event->userownerid] = $newuser; } //var_dump($cacheusers[$event->userownerid]->color); // We decide to choose color of owner of event (event->userownerid is user id of owner, event->userassigned contains all users assigned to event) if (!empty($cacheusers[$event->userownerid]->color)) { $color = $cacheusers[$event->userownerid]->color; } if (getDolGlobalString('AGENDA_USE_COLOR_PER_EVENT_TYPE')) { $color = $event->type_color; } } elseif ($event->type_code == 'ICALEVENT') { $numical++; if (!empty($event->icalname)) { if (!isset($numicals[dol_string_nospecial($event->icalname)])) { $numicals[dol_string_nospecial($event->icalname)] = 0; } $numicals[dol_string_nospecial($event->icalname)]++; } $color = $event->icalcolor; $cssclass = (!empty($event->icalname) ? 'family_ext'.md5($event->icalname) : 'family_other unsortable'); } elseif ($event->type_code == 'BIRTHDAY') { $numbirthday++; $colorindex = 2; $cssclass = 'family_birthday unsortable'; $color = sprintf("%02x%02x%02x", $theme_datacolor[$colorindex][0], $theme_datacolor[$colorindex][1], $theme_datacolor[$colorindex][2]); } else { $numother++; $color = ($event->icalcolor ? $event->icalcolor : -1); $cssclass = (!empty($event->icalname) ? 'family_ext'.md5($event->icalname) : 'family_other'); if (empty($cacheusers[$event->userownerid])) { $newuser = new User($db); $newuser->fetch($event->userownerid); $cacheusers[$event->userownerid] = $newuser; } //var_dump($cacheusers[$event->userownerid]->color); // We decide to choose color of owner of event (event->userownerid is user id of owner, event->userassigned contains all users assigned to event) if (!empty($cacheusers[$event->userownerid]->color)) { $color = $cacheusers[$event->userownerid]->color; } if (getDolGlobalString('AGENDA_USE_COLOR_PER_EVENT_TYPE')) { $color = $event->type_color; } } if ($color < 0) { // Color was not set on user card. Set color according to color index. // Define color index if not yet defined $idusertouse = ($event->userownerid ? $event->userownerid : 0); if (isset($colorindexused[$idusertouse])) { $colorindex = $colorindexused[$idusertouse]; // Color already assigned to this user } else { $colorindex = $nextindextouse; $colorindexused[$idusertouse] = $colorindex; if (!empty($theme_datacolor[$nextindextouse + 1])) { $nextindextouse++; // Prepare to use next color } } // Define color $color = sprintf("%02x%02x%02x", $theme_datacolor[$colorindex][0], $theme_datacolor[$colorindex][1], $theme_datacolor[$colorindex][2]); } // Define all rects with event (cases1 is first quarter hour, cases2 is second quarter hour, cases3 is second thirds hour, cases4 is 4th quarter hour) for ($h = $begin_h; $h < $end_h; $h++) { //if ($username->id == 1 && $day==1) print 'h='.$h; $newcolor = ''; //init if (empty($event->fulldayevent)) { $a = dol_mktime((int) $h, 0, 0, $month, $day, $year, 'tzuserrel', 0); $b = dol_mktime((int) $h, 15, 0, $month, $day, $year, 'tzuserrel', 0); $b1 = dol_mktime((int) $h, 30, 0, $month, $day, $year, 'tzuserrel', 0); $b2 = dol_mktime((int) $h, 45, 0, $month, $day, $year, 'tzuserrel', 0); $c = dol_mktime((int) $h + 1, 0, 0, $month, $day, $year, 'tzuserrel', 0); $dateendtouse = $event->date_end_in_calendar; if ($dateendtouse == $event->date_start_in_calendar) { $dateendtouse++; } //print dol_print_date($event->date_start_in_calendar,'dayhour').'-'.dol_print_date($a,'dayhour').'-'.dol_print_date($b,'dayhour').'
'; if ($event->date_start_in_calendar < $b && $dateendtouse > $a) { $busy = $event->transparency; $cases1[$h][$event->id]['busy'] = $busy; $cases1[$h][$event->id]['string'] = dol_print_date($event->date_start_in_calendar, 'dayhour', 'tzuserrel'); if ($event->date_end_in_calendar && $event->date_end_in_calendar != $event->date_start_in_calendar) { $tmpa = dol_getdate($event->date_start_in_calendar, true); $tmpb = dol_getdate($event->date_end_in_calendar, true); if ($tmpa['mday'] == $tmpb['mday'] && $tmpa['mon'] == $tmpb['mon'] && $tmpa['year'] == $tmpb['year']) { $cases1[$h][$event->id]['string'] .= '-'.dol_print_date($event->date_end_in_calendar, 'hour', 'tzuserrel'); } else { $cases1[$h][$event->id]['string'] .= '-'.dol_print_date($event->date_end_in_calendar, 'dayhour', 'tzuserrel'); } } if ($event->label) { $cases1[$h][$event->id]['string'] .= ' - '.$event->label; } $cases1[$h][$event->id]['typecode'] = $event->type_code; if ($event->type_code == 'HOLIDAY') { $cases1[$h][$event->id]['css'] = 'peruser_holiday '; } else { $cases1[$h][$event->id]['color'] = $color; if ($event->fk_project > 0) { if (empty($cacheprojects[$event->fk_project])) { $tmpproj = new Project($db); $tmpproj->fetch($event->fk_project); $cacheprojects[$event->fk_project] = $tmpproj; } $cases1[$h][$event->id]['string'] .= ', '.$langs->trans("Project").': '.$cacheprojects[$event->fk_project]->ref.' - '.$cacheprojects[$event->fk_project]->title; } if ($event->socid > 0) { if (empty($cachethirdparties[$event->socid])) { $tmpthirdparty = new Societe($db); $tmpthirdparty->fetch($event->socid); $cachethirdparties[$event->socid] = $tmpthirdparty; } $cases1[$h][$event->id]['string'] .= ', '.$cachethirdparties[$event->socid]->name; } if ($event->contact_id > 0) { if (empty($cachecontacts[$event->contact_id])) { $tmpcontact = new Contact($db); $tmpcontact->fetch($event->contact_id); $cachecontacts[$event->contact_id] = $tmpcontact; } $cases1[$h][$event->id]['string'] .= ', '.$cachecontacts[$event->contact_id]->getFullName($langs); } } } if ($event->date_start_in_calendar < $b1 && $dateendtouse > $b) { $busy = $event->transparency; $cases2[$h][$event->id]['busy'] = $busy; $cases2[$h][$event->id]['string'] = dol_print_date($event->date_start_in_calendar, 'dayhour', 'tzuserrel'); if ($event->date_end_in_calendar && $event->date_end_in_calendar != $event->date_start_in_calendar) { $tmpa = dol_getdate($event->date_start_in_calendar, true); $tmpb = dol_getdate($event->date_end_in_calendar, true); if ($tmpa['mday'] == $tmpb['mday'] && $tmpa['mon'] == $tmpb['mon'] && $tmpa['year'] == $tmpb['year']) { $cases2[$h][$event->id]['string'] .= '-'.dol_print_date($event->date_end_in_calendar, 'hour', 'tzuserrel'); } else { $cases2[$h][$event->id]['string'] .= '-'.dol_print_date($event->date_end_in_calendar, 'dayhour', 'tzuserrel'); } } if ($event->label) { $cases2[$h][$event->id]['string'] .= ' - '.$event->label; } $cases2[$h][$event->id]['typecode'] = $event->type_code; if ($event->type_code == 'HOLIDAY') { $cases2[$h][$event->id]['css'] = 'peruser_holiday '; } else { $cases2[$h][$event->id]['color'] = $color; if ($event->fk_project > 0) { if (empty($cacheprojects[$event->fk_project])) { $tmpproj = new Project($db); $tmpproj->fetch($event->fk_project); $cacheprojects[$event->fk_project] = $tmpproj; } $cases2[$h][$event->id]['string'] .= ', '.$langs->trans("Project").': '.$cacheprojects[$event->fk_project]->ref.' - '.$cacheprojects[$event->fk_project]->title; } if ($event->socid > 0) { if (empty($cachethirdparties[$event->socid])) { $tmpthirdparty = new Societe($db); $tmpthirdparty->fetch($event->socid); $cachethirdparties[$event->socid] = $tmpthirdparty; } $cases2[$h][$event->id]['string'] .= ', '.$cachethirdparties[$event->socid]->name; } if ($event->contact_id > 0) { if (empty($cachecontacts[$event->contact_id])) { $tmpcontact = new Contact($db); $tmpcontact->fetch($event->contact_id); $cachecontacts[$event->contact_id] = $tmpcontact; } $cases2[$h][$event->id]['string'] .= ', '.$cachecontacts[$event->contact_id]->getFullName($langs); } } } if ($event->date_start_in_calendar < $b2 && $dateendtouse > $b1) { $busy = $event->transparency; $cases3[$h][$event->id]['busy'] = $busy; $cases3[$h][$event->id]['string'] = dol_print_date($event->date_start_in_calendar, 'dayhour', 'tzuserrel'); if ($event->date_end_in_calendar && $event->date_end_in_calendar != $event->date_start_in_calendar) { $tmpa = dol_getdate($event->date_start_in_calendar, true); $tmpb = dol_getdate($event->date_end_in_calendar, true); if ($tmpa['mday'] == $tmpb['mday'] && $tmpa['mon'] == $tmpb['mon'] && $tmpa['year'] == $tmpb['year']) { $cases3[$h][$event->id]['string'] .= '-'.dol_print_date($event->date_end_in_calendar, 'hour', 'tzuserrel'); } else { $cases3[$h][$event->id]['string'] .= '-'.dol_print_date($event->date_end_in_calendar, 'dayhour', 'tzuserrel'); } } if ($event->label) { $cases3[$h][$event->id]['string'] .= ' - '.$event->label; } $cases3[$h][$event->id]['typecode'] = $event->type_code; if ($event->type_code == 'HOLIDAY') { $cases3[$h][$event->id]['css'] .= 'peruser_holiday '; } else { $cases3[$h][$event->id]['color'] = $color; if ($event->fk_project > 0) { if (empty($cacheprojects[$event->fk_project])) { $tmpproj = new Project($db); $tmpproj->fetch($event->fk_project); $cacheprojects[$event->fk_project] = $tmpproj; } $cases3[$h][$event->id]['string'] .= ', '.$langs->trans("Project").': '.$cacheprojects[$event->fk_project]->ref.' - '.$cacheprojects[$event->fk_project]->title; } if ($event->socid > 0) { if (empty($cachethirdparties[$event->socid])) { $tmpthirdparty = new Societe($db); $tmpthirdparty->fetch($event->socid); $cachethirdparties[$event->socid] = $tmpthirdparty; } $cases3[$h][$event->id]['string'] .= ', '.$cachethirdparties[$event->socid]->name; } if ($event->contact_id > 0) { if (empty($cachecontacts[$event->contact_id])) { $tmpcontact = new Contact($db); $tmpcontact->fetch($event->contact_id); $cachecontacts[$event->contact_id] = $tmpcontact; } $cases3[$h][$event->id]['string'] .= ', '.$cachecontacts[$event->contact_id]->getFullName($langs); } } } if ($event->date_start_in_calendar < $c && $dateendtouse > $b2) { $busy = $event->transparency; $cases4[$h][$event->id]['busy'] = $busy; $cases4[$h][$event->id]['string'] = dol_print_date($event->date_start_in_calendar, 'dayhour', 'tzuserrel'); if ($event->date_end_in_calendar && $event->date_end_in_calendar != $event->date_start_in_calendar) { $tmpa = dol_getdate($event->date_start_in_calendar, true); $tmpb = dol_getdate($event->date_end_in_calendar, true); if ($tmpa['mday'] == $tmpb['mday'] && $tmpa['mon'] == $tmpb['mon'] && $tmpa['year'] == $tmpb['year']) { $cases4[$h][$event->id]['string'] .= '-'.dol_print_date($event->date_end_in_calendar, 'hour', 'tzuserrel'); } else { $cases4[$h][$event->id]['string'] .= '-'.dol_print_date($event->date_end_in_calendar, 'dayhour', 'tzuserrel'); } } if ($event->label) { $cases4[$h][$event->id]['string'] .= ' - '.$event->label; } $cases4[$h][$event->id]['typecode'] = $event->type_code; if ($event->type_code == 'HOLIDAY') { $cases4[$h][$event->id]['css'] = 'peruser_holiday '; } else { $cases4[$h][$event->id]['color'] = $color; if ($event->fk_project > 0) { if (empty($cacheprojects[$event->fk_project])) { $tmpproj = new Project($db); $tmpproj->fetch($event->fk_project); $cacheprojects[$event->fk_project] = $tmpproj; } $cases4[$h][$event->id]['string'] .= ', '.$langs->trans("Project").': '.$cacheprojects[$event->fk_project]->ref.' - '.$cacheprojects[$event->fk_project]->title; } if ($event->socid > 0) { if (empty($cachethirdparties[$event->socid])) { $tmpthirdparty = new Societe($db); $tmpthirdparty->fetch($event->socid); $cachethirdparties[$event->socid] = $tmpthirdparty; } $cases4[$h][$event->id]['string'] .= ', '.$cachethirdparties[$event->socid]->name; } if ($event->contact_id > 0) { if (empty($cachecontacts[$event->contact_id])) { $tmpcontact = new Contact($db); $tmpcontact->fetch($event->contact_id); $cachecontacts[$event->contact_id] = $tmpcontact; } $cases4[$h][$event->id]['string'] .= ', '.$cachecontacts[$event->contact_id]->getFullName($langs); } } } } else { $busy = $event->transparency; $cases1[$h][$event->id]['busy'] = $busy; $cases2[$h][$event->id]['busy'] = $busy; $cases3[$h][$event->id]['busy'] = $busy; $cases4[$h][$event->id]['busy'] = $busy; $cases1[$h][$event->id]['string'] = $event->label; $cases2[$h][$event->id]['string'] = $event->label; $cases3[$h][$event->id]['string'] = $event->label; $cases4[$h][$event->id]['string'] = $event->label; $cases1[$h][$event->id]['typecode'] = $event->type_code; $cases2[$h][$event->id]['typecode'] = $event->type_code; $cases3[$h][$event->id]['typecode'] = $event->type_code; $cases4[$h][$event->id]['typecode'] = $event->type_code; $cases1[$h][$event->id]['color'] = $color; $cases2[$h][$event->id]['color'] = $color; $cases3[$h][$event->id]['color'] = $color; $cases4[$h][$event->id]['color'] = $color; $cases1[$h][$event->id]['css'] = ''; $cases2[$h][$event->id]['css'] = ''; $cases3[$h][$event->id]['css'] = ''; $cases4[$h][$event->id]['css'] = ''; } } $i++; } break; // We found the date we were looking for. No need to search anymore. } } // Now output $casesX from start hour to end hour for ($h = $begin_h; $h < $end_h; $h++) { $color1 = ''; $color2 = ''; $color3 = ''; $color4 = ''; $style1 = 'onclickopenref '; $style2 = 'onclickopenref '; $style3 = 'onclickopenref '; $style4 = 'onclickopenref '; $string1 = ' '; $string2 = ' '; $string3 = ' '; $string4 = ' '; $title1 = ''; $title2 = ''; $title3 = ''; $title4 = ''; if (isset($cases1[$h]) && $cases1[$h] != '') { //$title1.=count($cases1[$h]).' '.(count($cases1[$h])==1?$langs->trans("Event"):$langs->trans("Events")); if (count($cases1[$h]) > 1) { $title1 .= count($cases1[$h]).' '.(count($cases1[$h]) == 1 ? $langs->trans("Event") : $langs->trans("Events")); } if (!getDolGlobalString('AGENDA_NO_TRANSPARENT_ON_NOT_BUSY')) { $style1 .= 'peruser_notbusy '; } else { $style1 .= 'peruser_busy '; } foreach ($cases1[$h] as $id => $ev) { if ($ev['busy']) { $style1 = 'onclickopenref peruser_busy'; } if ($ev['css']) { $style1 .= ' '.$ev['css']; } } } if (isset($cases2[$h]) && $cases2[$h] != '') { //$title2.=count($cases2[$h]).' '.(count($cases2[$h])==1?$langs->trans("Event"):$langs->trans("Events")); if (count($cases2[$h]) > 1) { $title2 .= count($cases2[$h]).' '.(count($cases2[$h]) == 1 ? $langs->trans("Event") : $langs->trans("Events")); } if (!getDolGlobalString('AGENDA_NO_TRANSPARENT_ON_NOT_BUSY')) { $style2 .= 'peruser_notbusy '; } else { $style2 .= 'peruser_busy '; } foreach ($cases2[$h] as $id => $ev) { if ($ev['busy']) { $style2 = 'onclickopenref peruser_busy'; } if ($ev['css']) { $style2 .= ' '.$ev['css']; } } } if (isset($cases3[$h]) && $cases3[$h] != '') { //$title3.=count($cases3[$h]).' '.(count($cases3[$h])==1?$langs->trans("Event"):$langs->trans("Events")); if (count($cases3[$h]) > 1) { $title3 .= count($cases3[$h]).' '.(count($cases3[$h]) == 1 ? $langs->trans("Event") : $langs->trans("Events")); } if (!getDolGlobalString('AGENDA_NO_TRANSPARENT_ON_NOT_BUSY')) { $style3 .= 'peruser_notbusy '; } else { $style3 .= 'peruser_busy '; } foreach ($cases3[$h] as $id => $ev) { if ($ev['busy']) { $style3 = 'onclickopenref peruser_busy'; } if ($ev['css']) { $style3 .= ' '.$ev['css']; } } } if (isset($cases4[$h]) && $cases4[$h] != '') { //$title4.=count($cases3[$h]).' '.(count($cases3[$h])==1?$langs->trans("Event"):$langs->trans("Events")); if (count($cases4[$h]) > 1) { $title4 .= count($cases4[$h]).' '.(count($cases4[$h]) == 1 ? $langs->trans("Event") : $langs->trans("Events")); } if (!getDolGlobalString('AGENDA_NO_TRANSPARENT_ON_NOT_BUSY')) { $style4 .= 'peruser_notbusy '; } else { $style4 .= 'peruser_busy '; } foreach ($cases4[$h] as $id => $ev) { if ($ev['busy']) { $style4 = 'onclickopenref peruser_busy'; } if ($ev['css']) { $style4 .= ' '.$ev['css']; } } } $ids1 = ''; $ids2 = ''; $ids3 = ''; $ids4 = ''; if (!empty($cases1[$h]) && is_array($cases1[$h]) && count($cases1[$h]) && array_keys($cases1[$h])) { $ids1 = implode(', ', array_keys($cases1[$h])); } if (!empty($cases2[$h]) && is_array($cases2[$h]) && count($cases2[$h]) && array_keys($cases2[$h])) { $ids2 = implode(', ', array_keys($cases2[$h])); } if (!empty($cases3[$h]) && is_array($cases3[$h]) && count($cases3[$h]) && array_keys($cases3[$h])) { $ids3 = implode(',', array_keys($cases3[$h])); } if (!empty($cases4[$h]) && is_array($cases4[$h]) && count($cases4[$h]) && array_keys($cases4[$h])) { $ids4 = implode(',', array_keys($cases4[$h])); } if ($h == $begin_h) { echo ''; } else { echo ''; } // only 1 event if (!empty($cases1[$h]) && is_array($cases1[$h]) && count($cases1[$h]) == 1) { $output = array_slice($cases1[$h], 0, 1); $title1 = $langs->trans("Ref").' '.$ids1.($title1 ? ' - '.$title1 : ''); if ($output[0]['string']) { $title1 .= ($title1 ? ' - ' : '').$output[0]['string']; } if ($output[0]['color']) { $color1 = $output[0]['color']; } } elseif (!empty($cases1[$h]) && is_array($cases1[$h]) && count($cases1[$h]) > 1) { $title1 = $langs->trans("Ref").' '.$ids1.($title1 ? ' - '.$title1 : ''); $color1 = '222222'; } // only 1 event if (!empty($cases2[$h]) && is_array($cases2[$h]) && count($cases2[$h]) == 1) { $output = array_slice($cases2[$h], 0, 1); $title2 = $langs->trans("Ref").' '.$ids2.($title2 ? ' - '.$title2 : ''); if ($output[0]['string']) { $title2 .= ($title2 ? ' - ' : '').$output[0]['string']; } if ($output[0]['color']) { $color2 = $output[0]['color']; } } elseif (!empty($cases2[$h]) && is_array($cases2[$h]) && count($cases2[$h]) > 1) { $title2 = $langs->trans("Ref").' '.$ids2.($title2 ? ' - '.$title2 : ''); $color2 = '222222'; } // only 1 event if (!empty($cases3[$h]) && is_array($cases3[$h]) && count($cases3[$h]) == 1) { $output = array_slice($cases3[$h], 0, 1); $title3 = $langs->trans("Ref").' '.$ids3.($title3 ? ' - '.$title3 : ''); if ($output[0]['string']) { $title3 .= ($title3 ? ' - ' : '').$output[0]['string']; } if ($output[0]['color']) { $color3 = $output[0]['color']; } } elseif (!empty($cases3[$h]) && is_array($cases3[$h]) && count($cases3[$h]) > 1) { $title3 = $langs->trans("Ref").' '.$ids3.($title3 ? ' - '.$title3 : ''); $color3 = '222222'; } // only 1 event if (!empty($cases4[$h]) && is_array($cases4[$h]) && count($cases4[$h]) == 1) { $output = array_slice($cases4[$h], 0, 1); $title4 = $langs->trans("Ref").' '.$ids3.($title4 ? ' - '.$title4 : ''); if ($output[0]['string']) { $title4 .= ($title4 ? ' - ' : '').$output[0]['string']; } if ($output[0]['color']) { $color4 = $output[0]['color']; } } elseif (!empty($cases4[$h]) && is_array($cases4[$h]) && count($cases4[$h]) > 1) { $title4 = $langs->trans("Ref").' '.$ids4.($title4 ? ' - '.$title4 : ''); $color4 = '222222'; } print ''; print ''; print ''; print ''; print ''; print ''; print ''; print '
'; print $string1; print ''; print $string2; print ''; print $string3; print ''; print $string4; print '
'; print ''; } }