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.
461 lines
13 KiB
461 lines
13 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>
|
|
*/
|
|
|
|
// Resetting the course id.
|
|
$cidReset = true;
|
|
|
|
// Including some necessary library files.
|
|
require_once __DIR__.'/../inc/global.inc.php';
|
|
|
|
// Setting the section (for the tabs).
|
|
$this_section = SECTION_PLATFORM_ADMIN;
|
|
|
|
$interbreadcrumb[] = [
|
|
'url' => 'index.php',
|
|
'name' => get_lang('Administration'),
|
|
];
|
|
$toolName = get_lang('Trainers time report');
|
|
|
|
// Access restrictions.
|
|
api_protect_admin_script();
|
|
|
|
$form = new FormValidator('teacher_time_report', 'get');
|
|
$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 = Security::remove_XSS($formValues['from']);
|
|
}
|
|
|
|
if (!empty($formValues['until'])) {
|
|
$selectedUntil = Security::remove_XSS($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',
|
|
'ASC',
|
|
-1,
|
|
null,
|
|
api_get_current_access_url_id()
|
|
);
|
|
|
|
$sessionList = SessionManager::get_sessions_list([], ['name']);
|
|
$teacherList = UserManager::get_user_list(['status' => COURSEMANAGER]);
|
|
|
|
foreach ($courseList as $courseItem) {
|
|
$optionsCourses[$courseItem['code']] = $courseItem['title'];
|
|
}
|
|
|
|
foreach ($sessionList as $sessionItem) {
|
|
$optionsSessions[$sessionItem['id']] = $sessionItem['name'];
|
|
}
|
|
|
|
foreach ($teacherList as $teacherItem) {
|
|
$optionsTeachers[$teacherItem['user_id']] = $teacherItem['complete_name'];
|
|
}
|
|
|
|
$withFilter = false;
|
|
$reportTitle = get_lang('Time report including all courses and sessions, by teacher');
|
|
$reportSubTitle = sprintf(
|
|
get_lang('Time spent between %s and %s'),
|
|
$selectedFrom,
|
|
$selectedUntil
|
|
);
|
|
|
|
$timeReport = new TeacherTimeReport();
|
|
|
|
if (!empty($selectedCourse)) {
|
|
$withFilter = true;
|
|
$course = api_get_course_info($selectedCourse);
|
|
if (empty($course)) {
|
|
api_not_allowed(true);
|
|
}
|
|
$reportTitle = sprintf(get_lang('Time report for course %s'), $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[] = [
|
|
'session' => null,
|
|
'course' => [
|
|
'id' => $course['real_id'],
|
|
'name' => $course['title'],
|
|
],
|
|
'coach' => [
|
|
'userId' => $teacher['user_id'],
|
|
'lastname' => $teacher['lastname'],
|
|
'firstname' => $teacher['firstname'],
|
|
'username' => $teacher['username'],
|
|
'complete_name' => api_get_person_name(
|
|
$teacher['firstname'],
|
|
$teacher['lastname']
|
|
),
|
|
],
|
|
'total_time' => $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 (!empty($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[] = [
|
|
'session' => [
|
|
'id' => $session['id'],
|
|
'name' => $session['name'],
|
|
],
|
|
'course' => [
|
|
'id' => $course['real_id'],
|
|
'name' => $course['title'],
|
|
],
|
|
'coach' => [
|
|
'userId' => $coach['user_id'],
|
|
'lastname' => $coach['lastname'],
|
|
'firstname' => $coach['firstname'],
|
|
'username' => $coach['username'],
|
|
'complete_name' => api_get_person_name(
|
|
$coach['firstname'],
|
|
$coach['lastname']
|
|
),
|
|
],
|
|
'total_time' => $formattedTime,
|
|
];
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!empty($selectedSession)) {
|
|
$withFilter = true;
|
|
|
|
$session = api_get_session_info($selectedSession);
|
|
$sessionData = [
|
|
'id' => $session['id'],
|
|
'name' => $session['name'],
|
|
];
|
|
|
|
$reportTitle = sprintf(get_lang('Time report for session %s'), $session['name']);
|
|
$courses = SessionManager::get_course_list_by_session_id($selectedSession);
|
|
|
|
foreach ($courses as $course) {
|
|
$courseData = [
|
|
'id' => $course['id'],
|
|
'name' => $course['title'],
|
|
];
|
|
|
|
$coaches = CourseManager::get_coachs_from_course(
|
|
$selectedSession,
|
|
$course['id']
|
|
);
|
|
|
|
if (!empty($coaches)) {
|
|
foreach ($coaches as $coach) {
|
|
$totalTime = UserManager::getTimeSpentInCourses(
|
|
$coach['user_id'],
|
|
$course['id'],
|
|
$selectedSession,
|
|
$selectedFrom,
|
|
$selectedUntil
|
|
);
|
|
$formattedTime = api_format_time($totalTime);
|
|
|
|
$timeReport->data[] = [
|
|
'session' => $sessionData,
|
|
'course' => $courseData,
|
|
'coach' => [
|
|
'userId' => $coach['user_id'],
|
|
'lastname' => $coach['lastname'],
|
|
'firstname' => $coach['firstname'],
|
|
'username' => $coach['username'],
|
|
'complete_name' => api_get_person_name(
|
|
$coach['firstname'],
|
|
$coach['lastname']
|
|
),
|
|
],
|
|
'total_time' => $formattedTime,
|
|
];
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!empty($selectedTeacher)) {
|
|
$withFilter = true;
|
|
$teacher = api_get_user_info($selectedTeacher);
|
|
$teacherData = [
|
|
'userId' => $teacher['user_id'],
|
|
'lastname' => $teacher['lastname'],
|
|
'firstname' => $teacher['firstname'],
|
|
'username' => $teacher['username'],
|
|
'complete_name' => $teacher['complete_name'],
|
|
];
|
|
|
|
$reportTitle = sprintf(
|
|
get_lang('Time report for teacher %s'),
|
|
$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[] = [
|
|
'session' => null,
|
|
'course' => [
|
|
'id' => $courseInfo['real_id'],
|
|
'name' => $courseInfo['title'],
|
|
],
|
|
'coach' => $teacherData,
|
|
'total_time' => $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[] = [
|
|
'session' => [
|
|
'id' => $session->getId(),
|
|
'name' => $session->getName(),
|
|
],
|
|
'course' => [
|
|
'id' => $course->getId(),
|
|
'name' => $course->getTitle(),
|
|
],
|
|
'coach' => $teacherData,
|
|
'total_time' => $formattedTime,
|
|
];
|
|
}
|
|
}
|
|
|
|
if (empty($selectedCourse) && empty($selectedSession) &&
|
|
empty($selectedTeacher)
|
|
) {
|
|
foreach ($teacherList as &$teacher) {
|
|
$timeReport->data[] = [
|
|
'coach' => [
|
|
'username' => $teacher['username'],
|
|
'complete_name' => $teacher['complete_name'],
|
|
],
|
|
'total_time' => SessionManager::getTotalUserTimeInPlatform(
|
|
$teacher['user_id'],
|
|
$selectedFrom,
|
|
$selectedUntil
|
|
),
|
|
];
|
|
}
|
|
}
|
|
|
|
$timeReport->sortData($withFilter);
|
|
|
|
if (isset($_GET['export'])) {
|
|
$dataToExport = $timeReport->prepareDataToExport($withFilter);
|
|
$fileName = get_lang('Trainers time report').' '.api_get_local_time();
|
|
|
|
switch ($_GET['export']) {
|
|
case 'pdf':
|
|
$params = [
|
|
'filename' => $fileName,
|
|
'pdf_title' => "$reportTitle - $reportSubTitle",
|
|
'pdf_description' => get_lang('Trainers time report'),
|
|
'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, [
|
|
$reportTitle,
|
|
], [
|
|
$reportSubTitle,
|
|
], []);
|
|
|
|
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,
|
|
]);
|
|
|
|
$leftActions = Display::url(
|
|
Display::return_icon(
|
|
'session.png',
|
|
get_lang('Course sessions'),
|
|
[],
|
|
ICON_SIZE_MEDIUM
|
|
),
|
|
api_get_path(WEB_CODE_PATH).'admin/teachers_time_by_session_report.php'
|
|
);
|
|
$exportUrlParams = [
|
|
'from' => $selectedFrom,
|
|
'until' => $selectedUntil,
|
|
'course' => $selectedCourse,
|
|
'session' => $selectedSession,
|
|
'teacher' => $selectedTeacher,
|
|
'_qf__teacher_time_report' => '',
|
|
];
|
|
$rightActions = Display::url(
|
|
Display::return_icon(
|
|
'pdf.png',
|
|
get_lang('Export to PDF'),
|
|
[],
|
|
ICON_SIZE_MEDIUM
|
|
),
|
|
api_get_self().'?export=pdf&'.http_build_query($exportUrlParams)
|
|
);
|
|
$rightActions .= Display::url(
|
|
Display::return_icon(
|
|
'export_excel.png',
|
|
get_lang('Excel export'),
|
|
[],
|
|
ICON_SIZE_MEDIUM
|
|
),
|
|
api_get_self().'?export=xls&'.http_build_query($exportUrlParams)
|
|
);
|
|
|
|
$tpl = new Template($toolName);
|
|
$tpl->assign('report_title', $reportTitle);
|
|
$tpl->assign('report_sub_title', $reportSubTitle);
|
|
$tpl->assign('selected_course', $selectedCourse);
|
|
$tpl->assign('selected_session', $selectedSession);
|
|
$tpl->assign('selected_teacher', $selectedTeacher);
|
|
$tpl->assign('selected_from', $selectedFrom);
|
|
$tpl->assign('selected_until', $selectedUntil);
|
|
$tpl->assign('with_filter', $withFilter);
|
|
$tpl->assign('courses', $courseList);
|
|
$tpl->assign('sessions', $sessionList);
|
|
$tpl->assign('form', $form->returnForm());
|
|
$tpl->assign('rows', $timeReport->data);
|
|
|
|
$templateName = $tpl->get_template('admin/teacher_time_report.tpl');
|
|
$contentTemplate = $tpl->fetch($templateName);
|
|
$tpl->assign('header', get_lang('Trainers time report'));
|
|
$tpl->assign(
|
|
'actions',
|
|
Display::toolbarAction(
|
|
'teacher_time_report_actions',
|
|
[$leftActions, $rightActions]
|
|
)
|
|
);
|
|
$tpl->assign('content', $contentTemplate);
|
|
$tpl->display_one_col_template();
|
|
|