|
|
|
|
@ -11,6 +11,7 @@ require_once api_get_path(LIBRARY_PATH).'tracking.lib.php'; |
|
|
|
|
require_once api_get_path(LIBRARY_PATH).'course.lib.php'; |
|
|
|
|
require_once api_get_path(LIBRARY_PATH).'usermanager.lib.php'; |
|
|
|
|
require_once api_get_path(LIBRARY_PATH).'pear/Spreadsheet_Excel_Writer/Writer.php'; |
|
|
|
|
require_once api_get_path(SYS_CODE_PATH).'newscorm/learnpath.class.php'; |
|
|
|
|
|
|
|
|
|
$filename = 'reporting.xls'; |
|
|
|
|
|
|
|
|
|
@ -23,125 +24,172 @@ $my_courses = CourseManager::get_course_list_of_user_as_course_admin($user_id); |
|
|
|
|
$array = array(); |
|
|
|
|
|
|
|
|
|
$i = 0; |
|
|
|
|
$session_id = 0; |
|
|
|
|
|
|
|
|
|
if (!empty($my_courses)) { |
|
|
|
|
foreach ($my_courses as $course) { |
|
|
|
|
|
|
|
|
|
//Only show open courses |
|
|
|
|
$course_info = api_get_course_info($course['course_code']); |
|
|
|
|
//Only show open courses |
|
|
|
|
if ($course_info['visibility'] == 0) { |
|
|
|
|
continue; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
//$array[$i]['course'] = $course; |
|
|
|
|
|
|
|
|
|
$course_code = $course['course_code']; |
|
|
|
|
$course_info = api_get_course_info($course_code); |
|
|
|
|
|
|
|
|
|
$t_lp = Database :: get_course_table(TABLE_LP_MAIN, $course_info['dbName']); |
|
|
|
|
$sql_lp = "SELECT lp.name, lp.id FROM $t_lp lp WHERE lp.session_id = 0 LIMIT 1"; |
|
|
|
|
$rs_lp = Database::query($sql_lp); |
|
|
|
|
|
|
|
|
|
$array[$i]['lp'] = ''; |
|
|
|
|
if (Database :: num_rows($rs_lp) > 0) { |
|
|
|
|
$learnpath = Database :: fetch_row($rs_lp); |
|
|
|
|
$array[$i]['lp'] = $learnpath[0]; |
|
|
|
|
} |
|
|
|
|
//$teachers = CourseManager::get_teacher_list_from_course_code($course_code); |
|
|
|
|
$teacher_list = array($course_info['titular']); |
|
|
|
|
|
|
|
|
|
$teachers = CourseManager::get_teacher_list_from_course_code($course_code); |
|
|
|
|
$teacher_list = array(); |
|
|
|
|
|
|
|
|
|
$array[$i]['teachers'] = ''; |
|
|
|
|
/* |
|
|
|
|
if (!empty($teachers)) { |
|
|
|
|
foreach($teachers as $teacher) { |
|
|
|
|
$teacher_list[]= $teacher['firstname'].' '.$teacher['lastname']; |
|
|
|
|
} |
|
|
|
|
$array[$i]['teachers'] = implode(', ', $teacher_list); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
$array[$i]['course_name'] = $course['title']; |
|
|
|
|
*/ |
|
|
|
|
$tmp_students = CourseManager :: get_student_list_from_course_code($course['course_code'], false); |
|
|
|
|
|
|
|
|
|
//Cleaning students only REAL students |
|
|
|
|
$students = array(); |
|
|
|
|
foreach ($tmp_students as $student) { |
|
|
|
|
$user_info = api_get_user_info($student['user_id']); |
|
|
|
|
if ($user_info['status'] != STUDENT) { |
|
|
|
|
continue; |
|
|
|
|
} |
|
|
|
|
$students[] = $student['user_id']; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
$students = CourseManager :: get_student_list_from_course_code($course['course_code'], false); |
|
|
|
|
$count_students = 0; |
|
|
|
|
$tools = 0; |
|
|
|
|
$session_id = 0; |
|
|
|
|
$count_students_accessing = 0; |
|
|
|
|
$count_students_complete_all_activities = 0; |
|
|
|
|
$count_students_complete_all_activities_at_50 = 0; |
|
|
|
|
$total_time_spent = 0; |
|
|
|
|
$total_tools = 0; |
|
|
|
|
$total_average_progress = 0; |
|
|
|
|
$t_lp = Database :: get_course_table(TABLE_LP_MAIN, $course_info['dbName']); |
|
|
|
|
$sql_lp = "SELECT lp.name, lp.id FROM $t_lp lp WHERE lp.session_id = 0"; |
|
|
|
|
$rs_lp = Database::query($sql_lp); |
|
|
|
|
$t_lpi = Database :: get_course_table(TABLE_LP_ITEM, $course_info['dbName']); |
|
|
|
|
$t_news = Database :: get_course_table(TABLE_ANNOUNCEMENT, $course_info['dbName']); |
|
|
|
|
|
|
|
|
|
/* |
|
|
|
|
$total_tools_list = Tracking::get_tools_most_used_by_course($course_code, $session_id); |
|
|
|
|
$total_tools = 0; |
|
|
|
|
foreach($total_tools_list as $tool) { |
|
|
|
|
$total_tools += $tool['count_access_tool']; |
|
|
|
|
}*/ |
|
|
|
|
|
|
|
|
|
if (!empty($students)) { |
|
|
|
|
foreach ($students as $student) { |
|
|
|
|
$student_id = $student['user_id']; |
|
|
|
|
|
|
|
|
|
$avg_student_progress += Tracking :: get_avg_student_progress($student_id, $course_code); |
|
|
|
|
$myavg_temp = Tracking :: get_avg_student_score($student_id, $course_code); |
|
|
|
|
if (Database :: num_rows($rs_lp) > 0) { |
|
|
|
|
while ($learnpath = Database :: fetch_array($rs_lp)) { |
|
|
|
|
$lp_id = $learnpath['id']; |
|
|
|
|
|
|
|
|
|
$avg_progress_in_course = Tracking::get_avg_student_progress($student_id, $course_code, array(), $session_id); |
|
|
|
|
|
|
|
|
|
if (intval($avg_progress_in_course) == 100) { |
|
|
|
|
$count_students_complete_all_activities++; |
|
|
|
|
$lp_items = |
|
|
|
|
$array[$i]['lp'] = '<a href="'.api_get_path(WEB_CODE_PATH).'newscorm/lp_controller.php?cidReq='.$course_code.'&action=view&lp_id='.$lp_id.'" target="_blank">'.$learnpath['name'].'</a>'; |
|
|
|
|
|
|
|
|
|
$array[$i]['teachers'] = ''; |
|
|
|
|
if (!empty($teacher_list)) { |
|
|
|
|
$array[$i]['teachers'] = implode(', ', $teacher_list); |
|
|
|
|
} |
|
|
|
|
if (intval($avg_progress_in_course) > 0 && intval($avg_progress_in_course) <= 50) { |
|
|
|
|
$count_students_complete_all_activities_at_50 ++; |
|
|
|
|
} |
|
|
|
|
$total_average_progress +=$avg_progress_in_course; |
|
|
|
|
|
|
|
|
|
$time_spent = Tracking::get_time_spent_on_the_course($student_id, $course_code, $session_id); |
|
|
|
|
$total_time_spent += $time_spent; |
|
|
|
|
if (!empty($time_spent)) { |
|
|
|
|
$count_students_accessing++; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
$student_list = array(); |
|
|
|
|
foreach($students as $student) { |
|
|
|
|
$student_list []=$student['user_id']; |
|
|
|
|
$array[$i]['course_name'] = $course['title']; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$count_students_accessing = 0; |
|
|
|
|
$count_students_complete_all_activities = 0; |
|
|
|
|
$count_students_complete_all_activities_at_50 = 0; |
|
|
|
|
$total_time_spent = 0; |
|
|
|
|
$total_average_progress = 0; |
|
|
|
|
|
|
|
|
|
if (!empty($students)) { |
|
|
|
|
foreach ($students as $student_id) { |
|
|
|
|
$avg_student_progress = Tracking::get_avg_student_progress($student_id, $course_code, array($lp_id), $session_id); |
|
|
|
|
$myavg_temp = Tracking::get_avg_student_score($student_id, $course_code, array($lp_id), $session_id); |
|
|
|
|
$avg_progress_in_course = Tracking::get_avg_student_progress($student_id, $course_code, array($lp_id), $session_id); |
|
|
|
|
|
|
|
|
|
if (intval($avg_progress_in_course) == 100) { |
|
|
|
|
$count_students_complete_all_activities++; |
|
|
|
|
} |
|
|
|
|
if (intval($avg_progress_in_course) > 0 && intval($avg_progress_in_course) <= 50) { |
|
|
|
|
$count_students_complete_all_activities_at_50 ++; |
|
|
|
|
} |
|
|
|
|
$total_average_progress +=$avg_progress_in_course; |
|
|
|
|
|
|
|
|
|
$time_spent = Tracking::get_time_spent_on_the_course($student_id, $course_code, $session_id); |
|
|
|
|
$total_time_spent += $time_spent; |
|
|
|
|
if (!empty($time_spent)) { |
|
|
|
|
$count_students_accessing++; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
$student_count = count($students); |
|
|
|
|
|
|
|
|
|
$array[$i]['count_students'] = $student_count; |
|
|
|
|
$array[$i]['count_students_accessing'] = 0; |
|
|
|
|
$array[$i]['count_students_accessing_percentage'] = 0; |
|
|
|
|
$array[$i]['count_students_complete_all_activities_at_50'] = 0; |
|
|
|
|
$array[$i]['count_students_complete_all_activities'] = 0; |
|
|
|
|
$array[$i]['average_percentage_activities_completed_per_student'] = 0; |
|
|
|
|
$array[$i]['total_time_spent'] = 0; |
|
|
|
|
$array[$i]['average_time_spent_per_student'] = 0; |
|
|
|
|
$array[$i]['total_time_spent'] = 0; |
|
|
|
|
$array[$i]['average_time_spent_per_student'] = 0; |
|
|
|
|
//$array[$i]['tools_used'] = 0; |
|
|
|
|
$array[$i]['learnpath_docs'] = 0; |
|
|
|
|
$array[$i]['learnpath_exercises'] = 0; |
|
|
|
|
$array[$i]['learnpath_links'] = 0; |
|
|
|
|
$array[$i]['learnpath_forums'] = 0; |
|
|
|
|
$array[$i]['learnpath_assignments'] = 0; |
|
|
|
|
|
|
|
|
|
//registering the number of each category of |
|
|
|
|
//items in learning path |
|
|
|
|
$sql_lpi = "SELECT lpi.item_type FROM $t_lpi lpi WHERE lpi.lp_id = $lp_id ORDER BY item_type"; |
|
|
|
|
$res_lpi = Database::query($sql_lpi); |
|
|
|
|
while ($row_lpi = Database::fetch_array($res_lpi)) { |
|
|
|
|
switch($row_lpi['item_type']) { |
|
|
|
|
case 'document': |
|
|
|
|
$array[$i]['learnpath_docs']++; |
|
|
|
|
break; |
|
|
|
|
case 'quiz': |
|
|
|
|
$array[$i]['learnpath_exercises']++; |
|
|
|
|
break; |
|
|
|
|
case 'link': |
|
|
|
|
$array[$i]['learnpath_links']++; |
|
|
|
|
break; |
|
|
|
|
case 'forum': |
|
|
|
|
case 'thread': |
|
|
|
|
$array[$i]['learnpath_forums']++; |
|
|
|
|
break; |
|
|
|
|
case 'student_publication': |
|
|
|
|
$array[$i]['learnpath_assignments']++; |
|
|
|
|
break; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
// Count announcements |
|
|
|
|
$array[$i]['total_announcements'] = 0; |
|
|
|
|
$sql_news = "SELECT count(id) FROM $t_news"; |
|
|
|
|
$res_news = Database::query($sql_news); |
|
|
|
|
while ($row_news = Database::fetch_array($res_news)) { |
|
|
|
|
$array[$i]['total_announcements'] = $row_news[0]; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//@todo don't know what means this value |
|
|
|
|
$count_students_complete_all_activities_at_50 = 0; |
|
|
|
|
|
|
|
|
|
if (!empty($student_count)) { |
|
|
|
|
$array[$i]['count_students_accessing'] = $count_students_accessing; |
|
|
|
|
$array[$i]['count_students_accessing_percentage'] = round($count_students_accessing / $student_count *100 , 0); |
|
|
|
|
$array[$i]['count_students_complete_all_activities_at_50'] = $count_students_complete_all_activities; |
|
|
|
|
$array[$i]['count_students_complete_all_activities'] = round($count_students_complete_all_activities / $student_count *100 , 0);; |
|
|
|
|
$array[$i]['average_percentage_activities_completed_per_student'] = round($count_students_complete_all_activities/$student_count*100,2); |
|
|
|
|
$array[$i]['total_time_spent'] = 0; |
|
|
|
|
$array[$i]['average_time_spent_per_student'] = 0; |
|
|
|
|
|
|
|
|
|
if (!empty($total_time_spent)) { |
|
|
|
|
$array[$i]['total_time_spent'] = api_time_to_hms($total_time_spent); |
|
|
|
|
$array[$i]['average_time_spent_per_student'] = api_time_to_hms($total_time_spent / $student_count); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
$i++; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
$nb_assignments = Tracking::count_student_assignments($student_list, $course_code, $session_id); |
|
|
|
|
$messages = Tracking::count_student_messages($student_list, $course_code, $session_id); |
|
|
|
|
$links = Tracking::count_student_visited_links($student_list, $course_code, $session_id); |
|
|
|
|
$chat_last_connection = Tracking::chat_last_connection($student_list, $course_code, $session_id); |
|
|
|
|
$documents = Tracking::count_student_downloaded_documents($student_list, $course_code, $session_id); |
|
|
|
|
|
|
|
|
|
$total_tools += $nb_assignments + $messages + $links + $chat_last_connection + $documents; |
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
$student_count = count($students); |
|
|
|
|
|
|
|
|
|
$array[$i]['count_students'] = $student_count; |
|
|
|
|
$array[$i]['count_students_accessing'] = 0; |
|
|
|
|
$array[$i]['count_students_accessing_percentage'] = 0; |
|
|
|
|
$array[$i]['count_students_complete_all_activities_at_50'] = 0; |
|
|
|
|
$array[$i]['count_students_complete_all_activities'] = 0; |
|
|
|
|
$array[$i]['average_percentage_activities_completed_per_student'] = 0; |
|
|
|
|
$array[$i]['total_time_spent'] = 0; |
|
|
|
|
$array[$i]['average_time_spent_per_student'] = 0; |
|
|
|
|
$array[$i]['total_time_spent'] = 0; |
|
|
|
|
$array[$i]['average_time_spent_per_student'] = 0; |
|
|
|
|
$array[$i]['tools_used'] = 0; |
|
|
|
|
|
|
|
|
|
//@todo don't know what means this value |
|
|
|
|
$count_students_complete_all_activities_at_50 = 0; |
|
|
|
|
|
|
|
|
|
if (!empty($student_count)) { |
|
|
|
|
$array[$i]['count_students_accessing'] = $count_students_accessing; |
|
|
|
|
$array[$i]['count_students_accessing_percentage'] = round($count_students_accessing / $student_count *100 , 0); |
|
|
|
|
$array[$i]['count_students_complete_all_activities_at_50'] = $count_students_complete_all_activities; |
|
|
|
|
$array[$i]['count_students_complete_all_activities'] = round($count_students_complete_all_activities / $student_count *100 , 0);; |
|
|
|
|
$array[$i]['average_percentage_activities_completed_per_student'] = round($count_students_complete_all_activities/$student_count*100,2); |
|
|
|
|
$array[$i]['total_time_spent'] = 0; |
|
|
|
|
$array[$i]['average_time_spent_per_student'] = 0; |
|
|
|
|
|
|
|
|
|
if (!empty($total_time_spent)) { |
|
|
|
|
$array[$i]['total_time_spent'] = api_time_to_hms($total_time_spent); |
|
|
|
|
$array[$i]['average_time_spent_per_student'] = api_time_to_hms($total_time_spent / $student_count); |
|
|
|
|
} |
|
|
|
|
$array[$i]['tools_used'] = $total_tools; |
|
|
|
|
} |
|
|
|
|
$i++; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@ -158,7 +206,12 @@ $headers = array( |
|
|
|
|
get_lang('AverageOfActivitiesCompletedPerStudent'), |
|
|
|
|
get_lang('TotalTimeSpentInTheCourse'), |
|
|
|
|
get_lang('AverageTimePerStudentInCourse'), |
|
|
|
|
get_lang('NumberOfToolsAddedOrUsedByTeachers') |
|
|
|
|
get_lang('NumberOfDocumentsInLearnpath'), |
|
|
|
|
get_lang('NumberOfExercisesInLearnpath'), |
|
|
|
|
get_lang('NumberOfLinksInLearnpath'), |
|
|
|
|
get_lang('NumberOfForumsInLearnpath'), |
|
|
|
|
get_lang('NumberOfAssignmentsInLearnpath'), |
|
|
|
|
get_lang('NumberOfAnnouncementsInCourse'), |
|
|
|
|
); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|