123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393 |
- <?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);
|