Chamilo is a learning management system focused on ease of use and accessibility
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
chamilo-lms/main/admin/teacher_time_report.php

394 lines
12 KiB

<?php
/* For licensing terms, see /license.txt */
/**
* Generate a teacher time report in platform or sessions/courses
*
* @author Angel Fernando Quiroz Campos <angel.quiroz@beeznest.com>
* @package chamilo.admin
*/
/* INIT SECTION */
// Resetting the course id.
$cidReset = true;
// Including some necessary library files.
require_once '../inc/global.inc.php';
// Setting the section (for the tabs).
$this_section = SECTION_PLATFORM_ADMIN;
$interbreadcrumb[] = array("url" => 'index.php', "name" => get_lang('PlatformAdmin'));
$toolName = get_lang('TeacherTimeReport');
// Access restrictions.
api_protect_admin_script();
$form = new FormValidator('teacher_time_report');
$startDate = new DateTime(api_get_local_time());
$startDate->modify('first day of this month');
$limitDate = new DateTime(api_get_local_time());
$selectedCourse = null;
$selectedSession = 0;
$selectedTeacher = 0;
$selectedFrom = $startDate->format('Y-m-d');
$selectedUntil = $limitDate->format('Y-m-d');
if ($form->validate()) {
$formValues = $form->getSubmitValues();
$selectedCourse = $formValues['course'];
$selectedSession = $formValues['session'];
$selectedTeacher = $formValues['teacher'];
if (!empty($formValues['from'])) {
$selectedFrom = $formValues['from'];
}
if (!empty($formValues['until'])) {
$selectedUntil = $formValues['until'];
}
}
$optionsCourses = [0 => get_lang('None')];
$optionsSessions = [0 => get_lang('None')];
$optionsTeachers = [0 => get_lang('None')];
$courseList = CourseManager::get_courses_list(0, 0, 'title');
$sessionsList = SessionManager::get_sessions_list(array(), array('name'));
$teacherList = UserManager::getTeachersList();
foreach ($courseList as $courseItem) {
$optionsCourses[$courseItem['code']] = $courseItem['title'];
}
foreach ($sessionsList as $sessionItem) {
$optionsSessions[$sessionItem['id']] = $sessionItem['name'];
}
foreach ($teacherList as $teacherItem) {
$optionsTeachers[$teacherItem['user_id']] = $teacherItem['completeName'];
}
$withFilter = false;
$reportTitle = get_lang('TimeReportIncludingAllCoursesAndSessionsByTeacher');
$reportSubTitle = sprintf(get_lang('TimeSpentBetweenXAndY'), $selectedFrom, $selectedUntil);
$timeReport = new TeacherTimeReport();
if (!empty($selectedCourse)) {
$withFilter = true;
$course = api_get_course_info($selectedCourse);
$reportTitle = sprintf(get_lang('TimeReportForCourseX'), $course['title']);
$teachers = CourseManager::get_teacher_list_from_course_code($selectedCourse);
foreach ($teachers as $teacher) {
$totalTime = UserManager::getTimeSpentInCourses(
$teacher['user_id'],
$course['real_id'],
0,
$selectedFrom,
$selectedUntil
);
$formattedTime = api_format_time($totalTime);
$timeReport->data[] = array(
'session' => null,
'course' => array(
'id' => $course['real_id'],
'name' => $course['title']
),
'coach' => array(
'userId' => $teacher['user_id'],
'lastname' => $teacher['lastname'],
'firstname' => $teacher['firstname'],
'username' => $teacher['username'],
'completeName' => api_get_person_name($teacher['firstname'], $teacher['lastname'])
),
'totalTime' => $formattedTime
);
}
$sessionsByCourse = SessionManager::get_session_by_course($course['real_id']);
foreach ($sessionsByCourse as $session) {
$coaches = CourseManager::get_coachs_from_course($session['id'], $course['real_id']);
if ($coaches) {
foreach ($coaches as $coach) {
$totalTime = UserManager::getTimeSpentInCourses(
$coach['user_id'],
$course['real_id'],
$session['id'],
$selectedFrom,
$selectedUntil
);
$formattedTime = api_format_time($totalTime);
$timeReport->data[] = array(
'session' => array(
'id' => $session['id'],
'name' => $session['name']
),
'course' => array(
'id' => $course['real_id'],
'name' => $course['title']
),
'coach' => array(
'userId' => $coach['user_id'],
'lastname' => $coach['lastname'],
'firstname' => $coach['firstname'],
'username' => $coach['username'],
'completeName' => api_get_person_name($coach['firstname'], $coach['lastname'])
),
'totalTime' => $formattedTime
);
}
}
}
}
if (!empty($selectedSession)) {
$withFilter = true;
$session = api_get_session_info($selectedSession);
$sessionData = array(
'id' => $session['id'],
'name' => $session['name']
);
$reportTitle = sprintf(get_lang('TimeReportForSessionX'), $session['name']);
$courses = SessionManager::get_course_list_by_session_id($selectedSession);
foreach ($courses as $course) {
$courseData = array(
'id' => $course['id'],
'name' => $course['title']
);
$coaches = CourseManager::get_coachs_from_course($selectedSession, $course['id']);
if ($coaches) {
foreach ($coaches as $coach) {
$totalTime = UserManager::getTimeSpentInCourses(
$coach['user_id'],
$course['id'],
$selectedSession,
$selectedFrom,
$selectedUntil
);
$formattedTime = api_format_time($totalTime);
$timeReport->data[] = array(
'session' => $sessionData,
'course' => $courseData,
'coach' => array(
'userId' => $coach['user_id'],
'lastname' => $coach['lastname'],
'firstname' => $coach['firstname'],
'username' => $coach['username'],
'completeName' => api_get_person_name($coach['firstname'], $coach['lastname'])
),
'totalTime' => $formattedTime
);
}
}
}
}
if (!empty($selectedTeacher)) {
$withFilter = true;
$teacher = api_get_user_info();
$teacherData = array(
'userId' => $teacher['user_id'],
'lastname' => $teacher['lastname'],
'firstname' => $teacher['firstname'],
'username' => $teacher['username'],
'completeName' => $teacher['complete_name']
);
$reportTitle = sprintf(get_lang('TimeReportForTeacherX'), $teacher['complete_name']);
$courses = CourseManager::get_courses_list_by_user_id($selectedTeacher, false);
if (!empty($courses)) {
foreach ($courses as $course) {
$courseInfo = api_get_course_info_by_id($course['real_id']);
$totalTime = UserManager::getTimeSpentInCourses(
$selectedTeacher,
$course['real_id'],
0,
$selectedFrom,
$selectedUntil
);
$formattedTime = api_format_time($totalTime);
$timeReport->data[] = array(
'session' => null,
'course' => array(
'id' => $courseInfo['real_id'],
'name' => $courseInfo['title']
),
'coach' => $teacherData,
'totalTime' => $formattedTime
);
}
}
$coursesInSession = SessionManager::getCoursesListByCourseCoach($selectedTeacher);
foreach ($coursesInSession as $userCourseSubscription) {
$course = $userCourseSubscription->getCourse();
$session = $userCourseSubscription->getSession();
$totalTime = UserManager::getTimeSpentInCourses(
$selectedTeacher,
$course->getId(),
$session->getId(),
$selectedFrom,
$selectedUntil
);
$formattedTime = api_format_time($totalTime);
$timeReport->data[] = array(
'session' => [
'id' => $session->getId(),
'name' => $session->getName()
],
'course' => array(
'id' => $course->getId(),
'name' => $course->getTitle()
),
'coach' => $teacherData,
'totalTime' => $formattedTime
);
}
}
if (empty($selectedCourse) && empty($selectedSession) && empty($selectedTeacher)) {
foreach ($teacherList as &$teacher) {
$timeReport->data[] = array(
'coach' => array(
'username' => $teacher['username'],
'completeName' => $teacher['completeName'],
),
'totalTime' => SessionManager::getTotalUserTimeInPlatform(
$teacher['user_id'],
$selectedFrom,
$selectedUntil
)
);
}
}
$timeReport->sortData($withFilter);
if (isset($_GET['export'])) {
$dataToExport = $timeReport->prepareDataToExport($withFilter);
$fileName = get_lang('TeacherTimeReport') . ' ' . api_get_local_time();
switch ($_GET['export']) {
case 'pdf':
$params = array(
'add_signatures' => false,
'filename' => $fileName,
'pdf_title' => "$reportTitle - $reportSubTitle",
'pdf_description' => get_lang('TeacherTimeReport'),
'format' => 'A4-L',
'orientation' => 'L'
);
$pdfContent = Export::convert_array_to_html($dataToExport);
Export::export_html_to_pdf($pdfContent, $params);
break;
case 'xls':
array_unshift($dataToExport, array(
$reportTitle
), array(
$reportSubTitle
), array());
Export::export_table_xls_html($dataToExport, $fileName);
break;
}
die;
}
$form->addSelect(
'course',
get_lang('Course'),
$optionsCourses,
['id' => 'courses']
);
$form->addSelect(
'session',
get_lang('Session'),
$optionsSessions,
['id' => 'session']
);
$form->addSelect(
'teacher',
get_lang('Teacher'),
$optionsTeachers,
['id' => 'teacher']
);
$form->addDateRangePicker(
'daterange',
get_lang('Date'),
false,
[
'id' => 'daterange',
'maxDate' => $limitDate->format('Y-m-d'),
'format' => 'YYYY-MM-DD',
'timePicker' => 'false',
'value' => "$selectedFrom / $selectedUntil"
]
);
$form->addButtonFilter(get_lang('Filter'));
$form->addHidden('from', '');
$form->addHidden('until', '');
$form->setDefaults([
'course' => $selectedCourse,
'session' => $selectedSession,
'teacher' => $selectedTeacher,
'date_range' => "$selectedFrom / $selectedUntil",
'from' => $selectedFrom,
'until' => $selectedUntil
]);
$tpl = new Template($toolName);
$tpl->assign('reportTitle', $reportTitle);
$tpl->assign('reportSubTitle', $reportSubTitle);
$tpl->assign('selectedCourse', $selectedCourse);
$tpl->assign('selectedSession', $selectedSession);
$tpl->assign('selectedTeacher', $selectedTeacher);
$tpl->assign('selectedFrom', $selectedFrom);
$tpl->assign('selectedUntil', $selectedUntil);
$tpl->assign('withFilter', $withFilter);
$tpl->assign('courses', $courseList);
$tpl->assign('sessions', $sessionsList);
$tpl->assign('courseCoaches', $teacherList);
$tpl->assign('form', $form->returnForm());
$tpl->assign('rows', $timeReport->data);
$contentTemplate = $tpl->get_template('admin/teacher_time_report.tpl');
$tpl->display($contentTemplate);