*/ // 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();