123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461 |
- <?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();
|