, Ghent University @author: Toon Van Hoecke , Ghent University @author: Eric Remy (initial version) @version: 2.2 alpha @description: this file generates a general agenda of all items of the courses the user is registered for ============================================================================== version info: ------------- -> version 2.2 : Patrick Cool, patrick.cool@ugent.be, november 2004 Personal Agenda added. The user can add personal agenda items. The items are stored in a dokeos_user database because it is not course or platform based. A personal agenda view was also added. This lists all the personal agenda items of that user. -> version 2.1 : Patrick Cool, patrick.cool@ugent.be, , oktober 2004 This is the version that works with the Group based Agenda tool. -> version 2.0 (alpha): Patrick Cool, patrick.cool@ugent.be, , oktober 2004 The 2.0 version introduces besides the month view also a week- and day view. In the 2.5 (final) version it will be possible for the student to add his/her own agenda items. The platform administrator can however decide if the students are allowed to do this or not. The alpha version only contains the three views. The personal agenda feature is not yet completely finished. There are however already some parts of the code for adding a personal agenda item present. this code was not released in an official dokeos but was only used in the offical server of the Ghent University where it underwent serious testing -> version 1.5: Toon Van Hoecke, toon.vanhoecke@ugent.be, december 2003 -> version 1.0: Eric Remy, eremy@rmwc.edu, 6 Oct 2003 The tool was initially called master-calendar as it collects all the calendar items of all the courses one is subscribed to. It was very soon integrated in Dokeos as this was a really basic and very usefull tool. */ /** * Settings (you may alter this at will */ $setting_agenda_link = 'coursecode'; // valid values are coursecode and icon /** * This function retrieves all the agenda items of all the courses the user is subscribed to */ function get_myagendaitems($courses_dbs, $month, $year) { global $_user; global $_configuration; global $setting_agenda_link; $items = array (); // get agenda-items for every course foreach ($courses_dbs as $key => $array_course_info) { //databases of the courses $TABLEAGENDA = Database :: get_course_table(TABLE_AGENDA, $array_course_info["db"]); $TABLE_ITEMPROPERTY = Database :: get_course_table(TABLE_ITEM_PROPERTY, $array_course_info["db"]); $group_memberships = GroupManager :: get_group_ids($array_course_info["db"], $_user['user_id']); // if the user is administrator of that course we show all the agenda items if ($array_course_info['status'] == '1') { //echo "course admin"; $sqlquery = "SELECT DISTINCT agenda.*, item_property.* FROM ".$TABLEAGENDA." agenda, ".$TABLE_ITEMPROPERTY." item_property WHERE agenda.id = item_property.ref AND MONTH(agenda.start_date)='".$month."' AND YEAR(agenda.start_date)='".$year."' AND item_property.tool='".TOOL_CALENDAR_EVENT."' AND item_property.visibility='1' GROUP BY agenda.id ORDER BY start_date "; } // if the user is not an administrator of that course else { //echo "GEEN course admin"; if (is_array($group_memberships) && count($group_memberships)>0) { $sqlquery = "SELECT agenda.*, item_property.* FROM ".$TABLEAGENDA." agenda, ".$TABLE_ITEMPROPERTY." item_property WHERE agenda.id = item_property.ref AND MONTH(agenda.start_date)='".$month."' AND YEAR(agenda.start_date)='".$year."' AND item_property.tool='".TOOL_CALENDAR_EVENT."' AND ( item_property.to_user_id='".$_user['user_id']."' OR item_property.to_group_id IN (0, ".implode(", ", $group_memberships).") ) AND item_property.visibility='1' ORDER BY start_date "; } else { $sqlquery = "SELECT agenda.*, item_property.* FROM ".$TABLEAGENDA." agenda, ".$TABLE_ITEMPROPERTY." item_property WHERE agenda.id = item_property.ref AND MONTH(agenda.start_date)='".$month."' AND YEAR(agenda.start_date)='".$year."' AND item_property.tool='".TOOL_CALENDAR_EVENT."' AND ( item_property.to_user_id='".$_user['user_id']."' OR item_property.to_group_id='0') AND item_property.visibility='1' ORDER BY start_date "; } } $result = api_sql_query($sqlquery, __FILE__, __LINE__); while ($item = Database::fetch_array($result)) { $agendaday = date("j",strtotime($item['start_date'])); if(!isset($items[$agendaday])){$items[$agendaday]=array();} $time= date("H:i",strtotime($item['start_date'])); $URL = api_get_path(WEB_PATH)."main/calendar/agenda.php?cidReq=".urlencode($array_course_info["code"])."&day=$agendaday&month=$month&year=$year#$agendaday"; // RH //Patrick Cool: to highlight the relevant agenda item if ($setting_agenda_link == 'coursecode') { $title=$array_course_info['title']; $agenda_link = substr($title, 0, 14); } else { $agenda_link = Display::return_icon('course_home.gif'); } if(!isset($items[$agendaday][$item['start_date']])) { $items[$agendaday][$item['start_date']] = ''; } $items[$agendaday][$item['start_date']] .= "".$time." ".$agenda_link." ".Security::remove_XSS($item['title'])."
"; } } // sorting by hour for every day $agendaitems = array (); while (list ($agendaday, $tmpitems) = each($items)) { if(!isset($agendaitems[$agendaday])) { $agendaitems[$agendaday] = ''; } sort($tmpitems); while (list ($key, $val) = each($tmpitems)) { $agendaitems[$agendaday] .= $val; } } //print_r($agendaitems); return $agendaitems; } /** * Show the monthcalender of the given month * @param array Agendaitems * @param int Month number * @param int Year number * @param array Array of strings containing long week day names (deprecated, you can send an empty array instead) * @param string The month name * @return void Direct output */ function display_mymonthcalendar($agendaitems, $month, $year, $weekdaynames=array(), $monthName) { global $DaysShort,$course_path; //Handle leap year $numberofdays = array (0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31); if (($year % 400 == 0) or ($year % 4 == 0 and $year % 100 <> 0)) $numberofdays[2] = 29; //Get the first day of the month $dayone = getdate(mktime(0, 0, 0, $month, 1, $year)); //Start the week on monday $startdayofweek = $dayone['wday'] <> 0 ? ($dayone['wday'] - 1) : 6; $g_cc = (isset($_GET['courseCode'])?$_GET['courseCode']:''); $backwardsURL = api_get_self()."?coursePath=".urlencode($course_path)."&courseCode=".Security::remove_XSS($g_cc)."&action=view&view=month&month=". ($month == 1 ? 12 : $month -1)."&year=". ($month == 1 ? $year -1 : $year); $forewardsURL = api_get_self()."?coursePath=".urlencode($course_path)."&courseCode=".Security::remove_XSS($g_cc)."&action=view&view=month&month=". ($month == 12 ? 1 : $month +1)."&year=". ($month == 12 ? $year +1 : $year); echo "\n", "\n", "\n", "\n", "\n", "\n"; echo "\n"; for ($ii = 1; $ii < 8; $ii ++) { echo "\n"; } echo "\n"; $curday = -1; $today = getdate(); while ($curday <= $numberofdays[$month]) { echo "\n"; for ($ii = 0; $ii < 7; $ii ++) { if (($curday == -1) && ($ii == $startdayofweek)) { $curday = 1; } if (($curday > 0) && ($curday <= $numberofdays[$month])) { $bgcolor = $ii < 5 ? $class = "class=\"days_week\"" : $class = "class=\"days_weekend\""; $dayheader = "$curday
"; if (($curday == $today['mday']) && ($year == $today['year']) && ($month == $today['mon'])) { $dayheader = "$curday - ".get_lang("Today")."
"; $class = "class=\"days_today\""; } echo "\n"; $curday ++; } else { echo "\n"; } } echo "\n"; } echo "
«", $monthName, " ", $year, "»
", $DaysShort[$ii % 7], "
", "".$dayheader; if (!empty($agendaitems[$curday])) { echo "".$agendaitems[$curday].""; } echo " 
\n"; } /** * Show the mini calender of the given month */ function display_myminimonthcalendar($agendaitems, $month, $year, $monthName) { global $DaysShort,$course_path; //Handle leap year $numberofdays = array (0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31); if (($year % 400 == 0) or ($year % 4 == 0 and $year % 100 <> 0)) $numberofdays[2] = 29; //Get the first day of the month $dayone = getdate(mktime(0, 0, 0, $month, 1, $year)); //Start the week on monday $startdayofweek = $dayone['wday'] <> 0 ? ($dayone['wday'] - 1) : 6; $g_cc = (isset($_GET['courseCode'])?$_GET['courseCode']:''); $backwardsURL = api_get_self()."?coursePath=".urlencode($course_path)."&courseCode=".Security::remove_XSS($g_cc)."&month=". ($month == 1 ? 12 : $month -1)."&year=". ($month == 1 ? $year -1 : $year); $forewardsURL = api_get_self()."?coursePath=".urlencode($course_path)."&courseCode=".Security::remove_XSS($g_cc)."&month=". ($month == 12 ? 1 : $month +1)."&year=". ($month == 12 ? $year +1 : $year); echo "\n", "\n", "\n", "\n", "\n", "\n"; echo "\n"; for ($ii = 1; $ii < 8; $ii ++) { echo "\n"; } echo "\n"; $curday = -1; $today = getdate(); while ($curday <= $numberofdays[$month]) { echo "\n"; for ($ii = 0; $ii < 7; $ii ++) { if (($curday == -1) && ($ii == $startdayofweek)) { $curday = 1; } if (($curday > 0) && ($curday <= $numberofdays[$month])) { $bgcolor = $ii < 5 ? $class = "class=\"days_week\"" : $class = "class=\"days_weekend\""; $dayheader = "$curday"; if (($curday == $today['mday']) && ($year == $today['year']) && ($month == $today['mon'])) { $dayheader = "$curday"; $class = "class=\"days_today\""; } echo "\t\n"; $curday ++; } else { echo "\n"; } } echo "\n"; } echo "
«", $monthName, " ", $year, "»
", $DaysShort[$ii % 7], "
"; if (!empty($agendaitems[$curday])) { echo "".$dayheader.""; } else { echo $dayheader; } // "a".$dayheader." ".$agendaitems[$curday]."\n"; echo " 
\n"; } /** * This function shows all the forms that are needed form adding /editing a new personal agenda item * when there is no $id passed in the function we are adding a new agenda item, if there is a $id * we are editing * attention: we have to check that the student is editing an item that belongs to him/her */ function show_new_personal_item_form($id = "") { global $year, $MonthsLong; global $tbl_personal_agenda; global $_user; // we construct the default time and date data (used if we are not editing a personal agenda item) $today = getdate(); $day = $today['mday']; $month = $today['mon']; $year = $today['year']; $hours = $today['hours']; $minutes = $today['minutes']; // if an $id is passed to this function this means we are editing an item // we are loading the information here (we do this after everything else // to overwrite the default information) if ($id <> "") { $sql = "SELECT * FROM ".$tbl_personal_agenda." WHERE user='".$_user['user_id']."' AND id='".$id."'"; $result = api_sql_query($sql, __FILE__, __LINE__); $aantal = Database::num_rows($result); if ($aantal <> 0) { $row = Database::fetch_array($result); $year = substr($row['date'], 0, 4); $month = substr($row['date'], 5, 2); $day = substr($row['date'], 8, 2); $hours = substr($row['date'], 11, 2); $minutes = substr($row['date'], 14, 2); $title = $row['title']; $text = $row['text']; } else { return false; } } echo "
\n"; echo "\n"; echo "\t\n\t\t\n\t\n"; echo "\t\n\t\t"; // ********** The title field ********** \\ echo ""; // ********** The text field ********** \\ echo ""; // ********** The Submit button********** \\ echo ""; echo "

"; echo ($_GET['action'] == 'edit_personal_agenda_item') ? get_lang("ModifyPersonalCalendarItem") : get_lang("AddPersonalCalendarItem"); echo "

\n"; echo "\n"; echo "\t\t".get_lang("Date").": \n"; // ********** The form containing the days (0->31) ********** \\ echo "\n\n"; // ********** The form containing the months (jan->dec) ********** \\ echo "\n"; echo "\n\n"; // ********** The form containing the years ********** \\ echo "\n"; echo ""; echo "".Display::return_icon('calendar_select.gif', get_lang('Select'), array ('style' => 'vertical-align: middle;')).""; echo "  "; // ********** The form containing the hours (00->23) ********** \\ echo "\n"; echo get_lang("Time").": \n"; echo ""; // ********** The form containing the minutes ********** \\ echo ""; echo "
"; echo get_lang('Title').': '; echo "
"; //api_disp_html_area('frm_content', $text, '300px'); echo''; echo "
"; echo ''; echo "
\n
\n"; } /** * This function shows all the forms that are needed form adding a new personal agenda item */ function store_personal_item($day, $month, $year, $hour, $minute, $title, $content, $id = "") { global $tbl_personal_agenda; global $_user; //constructing the date $date = $year."-".$month."-".$day." ".$hour.":".$minute.":00"; if ($id <> "") { // we are updating $sql = "UPDATE ".$tbl_personal_agenda." SET user='".$_user['user_id']."', title='".$title."', text='".$content."', date='".$date."' WHERE id='".$id."'"; } else { // we are adding a new item $sql = "INSERT INTO $tbl_personal_agenda (user, title, text, date) VALUES ('".$_user['user_id']."','$title', '$content', '$date')"; } $result = api_sql_query($sql, __FILE__, __LINE__); } /** * This function finds all the courses (also those of sessions) of the user and returns an array containing the * database name of the courses. * Xritten by Noel Dieschburg */ function get_all_courses_of_user() { global $TABLECOURS; global $TABLECOURSUSER; global $_user; $tbl_session_course = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE); $tbl_session_course_user= Database :: get_main_table(TABLE_MAIN_SESSION_COURSE_USER); $tbl_session = Database :: get_main_table(TABLE_MAIN_SESSION); $sql_select_courses = "SELECT c.code k, c.visual_code vc, c.title i, c.tutor_name t, c.db_name db, c.directory dir, '5' as status FROM $TABLECOURS c, $tbl_session_course_user srcu WHERE srcu.id_user='".$_user['user_id']."' AND c.code=srcu.course_code UNION SELECT c.code k, c.visual_code vc, c.title i, c.tutor_name t, c.db_name db, c.directory dir, cru.status status FROM $TABLECOURS c, $TABLECOURSUSER cru WHERE cru.user_id='".$_user['user_id']."' AND c.code=cru.course_code"; $result = api_sql_query($sql_select_courses); while ($row = Database::fetch_array($result)) { // we only need the database name of the course $courses[] = array ("db" => $row['db'], "code" => $row['k'], "visual_code" => $row['vc'], "title" => $row['i'], "directory" => $row['dir'], "status" => $row['status']); } return $courses; } /** * This function finds all the courses of the user and returns an array containing the * database name of the courses. */ function get_courses_of_user() { global $TABLECOURS; global $TABLECOURSUSER; global $_user; $sql_select_courses = "SELECT course.code k, course.visual_code vc, course.title i, course.tutor_name t, course.db_name db, course.directory dir, course_rel_user.status status FROM $TABLECOURS course, $TABLECOURSUSER course_rel_user WHERE course.code = course_rel_user.course_code AND course_rel_user.user_id = '".$_user['user_id']."'"; $result = api_sql_query($sql_select_courses); while ($row = Database::fetch_array($result)) { // we only need the database name of the course $courses[] = array ("db" => $row['db'], "code" => $row['k'], "visual_code" => $row['vc'], "title" => $row['i'], "directory" => $row['dir'], "status" => $row['status']); } return $courses; } /** * This function retrieves all the personal agenda items and add them to the agenda items found by the other functions. */ function get_personal_agenda_items($agendaitems, $day = "", $month = "", $year = "", $week = "", $type) { global $tbl_personal_agenda; global $_user; global $_configuration; // 1. creating the SQL statement for getting the personal agenda items in MONTH view if ($type == "month_view" or $type == "") // we are in month view { $sql = "SELECT * FROM ".$tbl_personal_agenda." WHERE user='".$_user['user_id']."' and MONTH(date)='".$month."' AND YEAR(date) = '".$year."' ORDER BY date ASC"; } // 2. creating the SQL statement for getting the personal agenda items in WEEK view if ($type == "week_view") // we are in week view { $start_end_day_of_week = calculate_start_end_of_week($week, $year); $start_day = $start_end_day_of_week['start']['day']; $start_month = $start_end_day_of_week['start']['month']; $start_year = $start_end_day_of_week['start']['year']; $end_day = $start_end_day_of_week['end']['day']; $end_month = $start_end_day_of_week['end']['month']; $end_year = $start_end_day_of_week['end']['year']; // in sql statements you have to use year-month-day for date calculations $start_filter = $start_year."-".$start_month."-".$start_day." 00:00:00"; $end_filter = $end_year."-".$end_month."-".$end_day." 23:59:59"; $sql = " SELECT * FROM ".$tbl_personal_agenda." WHERE user='".$_user['user_id']."' AND date>='".$start_filter."' AND date<='".$end_filter."'"; } // 3. creating the SQL statement for getting the personal agenda items in DAY view if ($type == "day_view") // we are in day view { // we could use mysql date() function but this is only available from 4.1 and higher $start_filter = $year."-".$month."-".$day." 00:00:00"; $end_filter = $year."-".$month."-".$day." 23:59:59"; $sql = " SELECT * FROM ".$tbl_personal_agenda." WHERE user='".$_user['user_id']."' AND date>='".$start_filter."' AND date<='".$end_filter."'"; } //echo "day:".$day."/"; //echo "month:".$month."/"; //echo "year:".$year."/"; //echo "week:".$week."/"; //echo $type."

"; //echo "

".$sql."
"; global $_configuration; $root_url = $_configuration['root_web']; if ($_configuration['multiple_access_urls']==true) { $access_url_id = api_get_current_access_url_id(); if ($access_url_id != -1 ){ $url = api_get_access_url($access_url_id); $root_url = $url['url']; } } $result = api_sql_query($sql, __FILE__, __LINE__); while ($item = Database::fetch_array($result)) { // we break the date field in the database into a date and a time part $agenda_db_date = explode(" ", $item[date]); $date = $agenda_db_date[0]; $time = $agenda_db_date[1]; // we divide the date part into a day, a month and a year $agendadate = explode("-", $date); $year = intval($agendadate[0]); $month = intval($agendadate[1]); $day = intval($agendadate[2]); // we divide the time part into hour, minutes, seconds $agendatime = explode(":", $time); $hour = $agendatime[0]; $minute = $agendatime[1]; $second = $agendatime[2]; // if the student has specified a course we a add a link to that course if ($item['course'] <> "") { $url = $root_url."main/calendar/agenda.php?cidReq=".urlencode($item['course'])."&day=$day&month=$month&year=$year#$day"; // RH //Patrick Cool: to highlight the relevant agenda item $course_link = "".$item['course'].""; } else { $course_link = ""; } // Creating the array that will be returned. If we have week or month view we have an array with the date as the key // if we have a day_view we use a half hour as index => key 33 = 16h30 if ($type !== "day_view") // This is the array construction for the WEEK or MONTH view { $agendaitems[$day] .= "
$hour:$minute $course_link ".$item['title']."
"; } else // this is the array construction for the DAY view { $halfhour = 2 * $agendatime['0']; if ($agendatime['1'] >= '30') { $halfhour = $halfhour +1; } $agendaitems[$halfhour] .= "
$hour:$minute $course_link ".$item['title']."
"; } } //print_r($agendaitems); return $agendaitems; } /** * This function retrieves one personal agenda item returns it. * @param int The agenda item ID * @return array The results of the database query, or null if not found */ function get_personal_agenda_item($id) { $tbl_personal_agenda = Database :: get_user_personal_table(TABLE_PERSONAL_AGENDA); $id = Database::escape_string($id); // make sure events of the personal agenda can only be seen by the user himself $user = api_get_user_id(); $sql = " SELECT * FROM ".$tbl_personal_agenda." WHERE id=".$id." AND user = ".$user; $result = api_sql_query($sql, __FILE__, __LINE__); if(Database::num_rows($result)==1) { $item = Database::fetch_array($result); } else { $item = null; } return $item; } /** * This function retrieves all the personal agenda items of the user and shows * these items in one list (ordered by date and grouped by month (the month_bar) */ function show_personal_agenda() { global $tbl_personal_agenda; global $MonthsLong, $charset; global $_user; // The SQL statement that retrieves all the personal agenda items of this user $sql = "SELECT * FROM ".$tbl_personal_agenda." WHERE user='".$_user['user_id']."' ORDER BY date DESC"; $result = api_sql_query($sql, __FILE__, __LINE__); // variable initialisation $month_bar = ""; // setting the default day, month and year if (!$_GET['day'] AND !$_GET['month'] AND !$_GET['year']) { $today = getdate(); $year = $today['year']; $month = $today['mon']; $day = $today['mday']; } $export_icon = 'export.png'; $export_icon_low = 'export_low_fade.png'; $export_icon_high = 'export_high_fade.png'; // starting the table output echo "\n"; if (Database::num_rows($result) > 0) { while ($myrow = Database::fetch_array($result)) { /*-------------------------------------------------- display: the month bar --------------------------------------------------*/ if ($month_bar != date("m", strtotime($myrow["date"])).date("Y", strtotime($myrow["date"]))) { $month_bar = date("m", strtotime($myrow["date"])).date("Y", strtotime($myrow["date"])); echo "\n"; } // highlight: if a date in the small calendar is clicked we highlight the relevant items $db_date = (int) date("d", strtotime($myrow["date"])).date("n", strtotime($myrow["date"])).date("Y", strtotime($myrow["date"])); if ($_GET["day"].$_GET["month"].$_GET["year"] <> $db_date) { $style = "data"; $text_style = "text"; } else { $style = "datanow"; $text_style = "text"; } /*-------------------------------------------------- display: date and time --------------------------------------------------*/ echo "\t\n\t\t"; echo '"; echo '\n\t"; echo ""; /*-------------------------------------------------- display: the title --------------------------------------------------*/ echo ""; echo '\n\t"; echo "\n"; /*-------------------------------------------------- display: the content --------------------------------------------------*/ $content = $myrow['text']; $content = make_clickable($content); $content = text_filter($content); echo "\t\n\t\t"; /*-------------------------------------------------- display: the edit / delete icons --------------------------------------------------*/ echo "\t\n\t\t"; } } else { echo ''; } echo "
".$MonthsLong[date("n", strtotime($myrow["date"])) - 1]." ".date("Y", strtotime($myrow["date"]))."
'; // adding an internal anchor echo ""; echo date("d", strtotime($myrow["date"]))." ".$MonthsLong[date("n", strtotime($myrow["date"])) - 1]." ".date("Y", strtotime($myrow["date"]))." "; echo ucfirst(strftime(get_lang("timeNoSecFormat"), strtotime($myrow["date"]))); echo "'; echo ''.Display::return_icon($export_icon_high, get_lang('ExportiCalConfidential')).''; echo ''.Display::return_icon($export_icon_low, get_lang('ExportiCalPrivate')).''; echo ''.Display::return_icon($export_icon, get_lang('ExportiCalPublic')).''; echo "\n\t\t
'; echo $myrow['title']; echo "\n\t\t
"; echo $content; echo "
"; echo "".Display::return_icon('edit.gif', get_lang('Edit')).""; echo "".Display::return_icon('delete.gif', get_lang('Delete')).""; echo "
'.get_lang('NoAgendaItems').'
\n"; } /** * This function retrieves all the personal agenda items of the given user_id and shows * these items in one list (ordered by date and grouped by month (the month_bar) * @param int user id */ function show_simple_personal_agenda($user_id) { $tbl_personal_agenda = Database :: get_user_personal_table(TABLE_PERSONAL_AGENDA); global $MonthsLong, $charset; // The SQL statement that retrieves all the personal agenda items of this user $sql = "SELECT * FROM ".$tbl_personal_agenda." WHERE user='".$user_id."' ORDER BY date DESC"; $result = api_sql_query($sql, __FILE__, __LINE__); // variable initialisation $month_bar = ""; // setting the default day, month and year if (!$_GET['day'] AND !$_GET['month'] AND !$_GET['year']) { $today = getdate(); $year = $today['year']; $month = $today['mon']; $day = $today['mday']; } $export_icon = 'export.png'; $export_icon_low = 'export_low_fade.png'; $export_icon_high = 'export_high_fade.png'; $content = ''; // starting the table output if (Database::num_rows($result) > 0) { while ($myrow = Database::fetch_array($result)) { /*-------------------------------------------------- display: the month bar --------------------------------------------------*/ if ($month_bar != date("m", strtotime($myrow["date"])).date("Y", strtotime($myrow["date"]))) { $month_bar = date("m", strtotime($myrow["date"])).date("Y", strtotime($myrow["date"])); $content.= $MonthsLong[date("n", strtotime($myrow["date"])) - 1]." ".date("Y", strtotime($myrow["date"])); } // highlight: if a date in the small calendar is clicked we highlight the relevant items $db_date = (int) date("d", strtotime($myrow["date"])).date("n", strtotime($myrow["date"])).date("Y", strtotime($myrow["date"])); if ($_GET["day"].$_GET["month"].$_GET["year"] <> $db_date) { $style = "data"; $text_style = "text"; } else { $style = "datanow"; $text_style = "text"; } /*-------------------------------------------------- display: date and time --------------------------------------------------*/ // adding an internal anchor $content.= date("d", strtotime($myrow["date"]))." ".$MonthsLong[date("n", strtotime($myrow["date"])) - 1]." ".date("Y", strtotime($myrow["date"]))." "; $content.= ucfirst(strftime(get_lang("timeNoSecFormat"), strtotime($myrow["date"]))); /*-------------------------------------------------- display: the title --------------------------------------------------*/ $content.= '
'; $content.= $myrow['title']; $content.= '
'; /*-------------------------------------------------- display: the content --------------------------------------------------*/ /* $content = $myrow['title']; $content = make_clickable($content); $content = text_filter($content);*/ return $content; } } else { return $content; } } /** * This function deletes a personal agenda item * There is an additional check to make sure that one cannot delete an item that * does not belong to him/her */ function delete_personal_agenda($id) { global $tbl_personal_agenda; global $_user; if ($id <> '') { $sql = "SELECT * FROM ".$tbl_personal_agenda." WHERE user='".$_user['user_id']."' AND id='".$id."'"; $result = api_sql_query($sql, __FILE__, __LINE__); $aantal = Database::num_rows($result); if ($aantal <> 0) { $sql = "DELETE FROM ".$tbl_personal_agenda." WHERE user='".$_user['user_id']."' AND id='".$id."'"; $result = api_sql_query($sql, __FILE__, __LINE__); } } } /** * Get personal agenda items between two dates (=all events from all registered courses) * @param int user ID of the user * @param string Optional start date in datetime format (if no start date is given, uses today) * @param string Optional end date in datetime format (if no date is given, uses one year from now) * @return array Array of events ordered by start date, in [0]('datestart','dateend','title'),[1]('datestart','dateend','title','link','coursetitle') format, where datestart and dateend are in yyyyMMddhhmmss format. * @TODO Implement really personal events (from user DB) and global events (from main DB) */ function get_personal_agenda_items_between_dates($user_id, $date_start='', $date_end='') { $items = array (); if ($user_id != strval(intval($user_id))) { return $items; } if (empty($date_start)) { $date_start = date('Y-m-d H:i:s');} if (empty($date_end)) { $date_end = date('Y-m-d H:i:s',mktime(0, 0, 0, date("m"), date("d"), date("Y")+1));} $expr = '/\d{4}-\d{2}-\d{2}\ \d{2}:\d{2}:\d{2}/'; if(!preg_match($expr,$date_start)) { return $items; } if(!preg_match($expr,$date_end)) { return $items; } // get agenda-items for every course $courses = api_get_user_courses($user_id,false); require_once(api_get_path(LIBRARY_PATH).'groupmanager.lib.php'); foreach ($courses as $id => $course) { $c = api_get_course_info($course['code']); //databases of the courses $t_a = Database :: get_course_table(TABLE_AGENDA, $course['db']); $t_ip = Database :: get_course_table(TABLE_ITEM_PROPERTY, $course['db']); $group_memberships = GroupManager :: get_group_ids($course['db'], $user_id); // if the user is administrator of that course we show all the agenda items if ($course['status'] == '1') { //echo "course admin"; $sqlquery = "SELECT DISTINCT agenda.*, item_property.* FROM ".$t_a." agenda, ".$t_ip." item_property WHERE agenda.id = item_property.ref AND agenda.start_date>='$date_start' AND agenda.end_date<='$date_end' AND item_property.tool='".TOOL_CALENDAR_EVENT."' AND item_property.visibility='1' GROUP BY agenda.id ORDER BY start_date "; } // if the user is not an administrator of that course else { //echo "NOT course admin"; if (is_array($group_memberships) && count($group_memberships)>0) { $sqlquery = "SELECT agenda.*, item_property.* FROM ".$t_a." agenda, ".$t_ip." item_property WHERE agenda.id = item_property.ref AND agenda.start_date>='$date_start' AND agenda.end_date<='$date_end' AND item_property.tool='".TOOL_CALENDAR_EVENT."' AND ( item_property.to_user_id='".$user_id."' OR item_property.to_group_id IN (0, ".implode(", ", $group_memberships).") ) AND item_property.visibility='1' ORDER BY start_date "; } else { $sqlquery = "SELECT agenda.*, item_property.* FROM ".$t_a." agenda, ".$t_ip." item_property WHERE agenda.id = item_property.ref AND agenda.start_date>='$date_start' AND agenda.end_date<='$date_end' AND item_property.tool='".TOOL_CALENDAR_EVENT."' AND ( item_property.to_user_id='".$user_id."' OR item_property.to_group_id='0') AND item_property.visibility='1' ORDER BY start_date "; } } $result = api_sql_query($sqlquery, __FILE__, __LINE__); while ($item = Database::fetch_array($result)) { $agendaday = date("j",strtotime($item['start_date'])); $URL = api_get_path(WEB_PATH)."main/calendar/agenda.php?cidReq=".urlencode($course["code"])."&day=$agendaday&month=$month&year=$year#$agendaday"; list($year,$month,$day,$hour,$min,$sec) = split('[-: ]',$item['start_date']); $start_date = $year.$month.$day.$hour.$min; list($year,$month,$day,$hour,$min,$sec) = split('[-: ]',$item['end_date']); $end_date = $year.$month.$day.$hour.$min; $items[] = array( 'datestart'=>$start_date, 'dateend'=>$end_date, 'title'=>$item['title'], 'link'=>$URL, 'coursetitle'=>$c['name'], ); } } return $items; } ?>