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.
		
		
		
		
		
			
		
			
				
					
					
						
							388 lines
						
					
					
						
							12 KiB
						
					
					
				
			
		
		
	
	
							388 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
 | 
						|
 */
 | 
						|
 | 
						|
// 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[] = 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 (!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[] = 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 (!empty($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(
 | 
						|
                '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('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', $sessionsList);
 | 
						|
//$tpl->assign('courseCoaches', $teacherList);
 | 
						|
$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('content', $contentTemplate);
 | 
						|
$tpl->display_one_col_template();
 | 
						|
 |