'.get_lang('Print').'
'.get_lang('ExportAsCSV').'
';
if($isCoach)
{
/****************************************
* Infos about students of the coach
****************************************/
$a_students = Tracking :: get_student_followed_by_coach($_user['user_id']);
$a_courses = Tracking :: get_courses_followed_by_coach($_user['user_id']);
$nbStudents = count($a_students);
$totalTimeSpent = 0;
$totalCourses = 0;
$avgTotalProgress = 0;
$avgResultsToExercises = 0;
$nb_inactive_students = 0;
$nb_posts = $nb_assignments = 0;
foreach($a_students as $student_id)
{
// inactive students
if($last_connection_date = Tracking :: get_last_connection_date($student_id))
{
list($last_connection_date, $last_connection_hour) = explode(' ',$last_connection_date);
$last_connection_date = explode('-',$last_connection_date);
$last_connection_hour = explode(':',$last_connection_hour);
$last_connection_time = mktime($last_connection_hour[0],$last_connection_hour[1],$last_connection_hour[2],$last_connection_date[1],$last_connection_date[2],$last_connection_date[0]);
if(time()-(3600*24*7) > $last_connection_time)
{
$nb_inactive_students++;
}
}
else
{
$nb_inactive_students++;
}
$totalTimeSpent += Tracking :: get_time_spent_on_the_platform($student_id);
$totalCourses += Tracking :: count_course_per_student($student_id);
$avgStudentProgress = $avgStudentScore = 0;
$nb_courses_student = 0;
foreach($a_courses as $course_code)
{
if(CourseManager :: is_user_subscribed_in_course($student_id, $course_code, true))
{
$nb_courses_student++;
$nb_posts += Tracking :: count_student_messages($student_id,$course_code);
$nb_assignments += Tracking :: count_student_assignments($student_id,$course_code);
$avgStudentProgress += Tracking :: get_avg_student_progress($student_id,$course_code);
$avgStudentScore += Tracking :: get_avg_student_score($student_id,$course_code);
}
}
// average progress of the student
$avgStudentProgress = $avgStudentProgress / $nb_courses_student;
$avgTotalProgress += $avgStudentProgress;
// average test results of the student
$avgStudentScore = $avgStudentScore / $nb_courses_student;
$avgResultsToExercises += $avgStudentScore;
}
// average progress
$avgTotalProgress = $avgTotalProgress/$nbStudents;
// average results to the tests
$avgResultsToExercises = $avgResultsToExercises/$nbStudents;
// average courses by student
$avgCoursesPerStudent = round($totalCourses / $nbStudents,2);
// average time spent on the platform
$avgTimeSpent = $totalTimeSpent / $nbStudents;
// average assignments
$nb_assignments = $nb_assignments / $nbStudents;
// average posts
$nb_posts = $nb_posts / $nbStudents;
//csv part
if($export_csv)
{
$csv_content[] = array( get_lang('Probationers'));
$csv_content[] = array( get_lang('InactivesStudents'),$nb_inactive_students );
$csv_content[] = array( get_lang('AverageTimeSpentOnThePlatform'),$avgTimeSpent);
$csv_content[] = array( get_lang('AverageCoursePerStudent'),$avgCoursesPerStudent);
$csv_content[] = array( get_lang('AverageProgressInLearnpath'),$avgTotalProgress);
$csv_content[] = array( get_lang('AverageResultsToTheExercices'),$avgResultsToExercises);
$csv_content[] = array( get_lang('AveragePostsInForum'),$nb_posts);
$csv_content[] = array( get_lang('AverageAssignments'),$nb_assignments);
$csv_content[] = array();
}
// html part
else
{
echo '
'.get_lang('Probationers').' ('.$nbStudents.')'.'
| '.get_lang('InactivesStudents').' | '.$nb_inactive_students.' |
| '.get_lang('AverageTimeSpentOnThePlatform').' | '.api_time_to_hms($avgTimeSpent).' |
| '.get_lang('AverageCoursePerStudent').' | '.$avgCoursesPerStudent.' |
| '.get_lang('AverageProgressInLearnpath').' | '.round($avgTotalProgress,2).' % |
| '.get_lang('AverageResultsToTheExercices').' | '.round($avgResultsToExercises,2).' % |
| '.get_lang('AveragePostsInForum').' | '.round($nb_posts,2).' |
| '.get_lang('AverageAssignments').' | '.round($nb_assignments,2).' |
'.get_lang('Sessions').' ('.$nbSessions.')'.'
| '.get_lang('NbActiveSessions').' | '.$nb_sessions_current.' |
| '.get_lang('NbPastSessions').' | '.$nb_sessions_past.' |
| '.get_lang('NbFutureSessions').' | '.$nb_sessions_future.' |
| '.get_lang('NbStudentPerSession').' | '.round($nbStudents/$nbSessions,2).' |
| '.get_lang('NbCoursesPerSession').' | '.$nb_courses_per_session.' |
';
$csv_content[] = array(
$course['title'],
$nb_students_in_course,
$avg_time_spent_in_course,
$avg_progress_in_course,
$avg_score_in_course,
$avg_messages_in_course,
$avg_assignments_in_course,
);
$table -> addRow($table_row, 'align="right"');
}
$table -> updateColAttributes(0,array('align'=>'left'));
$table -> updateColAttributes(7,array('align'=>'center'));
$table -> display();
}
// send the csv file if asked
if($export_csv)
{
ob_end_clean();
Export :: export_table_csv($csv_content, 'reporting_index');
}
/*
==============================================================================
FOOTER
==============================================================================
*/
if(!$export_csv)
{
Display::display_footer();
}
?>