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.
		
		
		
		
		
			
		
			
				
					
					
						
							309 lines
						
					
					
						
							11 KiB
						
					
					
				
			
		
		
	
	
							309 lines
						
					
					
						
							11 KiB
						
					
					
				<?php
 | 
						|
/* For licensing terms, see /license.txt */
 | 
						|
/**
 | 
						|
 * List all certificates filtered by session/course and month/year
 | 
						|
 * @author Angel Fernando Quiroz Campos <angel.quiroz@beeznest.com>
 | 
						|
 * @package chamilo.gradebook
 | 
						|
 */
 | 
						|
use ChamiloSession as Session;
 | 
						|
 | 
						|
$cidReset = true;
 | 
						|
 | 
						|
require_once '../inc/global.inc.php';
 | 
						|
 | 
						|
$this_section = SECTION_TRACKING;
 | 
						|
 | 
						|
api_block_anonymous_users();
 | 
						|
 | 
						|
$interbreadcrumb[] = array(
 | 
						|
    "url" => api_get_path(WEB_CODE_PATH) . "mySpace/index.php",
 | 
						|
    "name" => get_lang("MySpace")
 | 
						|
);
 | 
						|
 | 
						|
$selectedSession = isset($_POST['session']) && !empty($_POST['session']) ? intval($_POST['session']) : 0;
 | 
						|
$selectedCourse = isset($_POST['course']) && !empty($_POST['course']) ? intval($_POST['course']) : 0;
 | 
						|
$selectedMonth = isset($_POST['month']) && !empty($_POST['month']) ? intval($_POST['month']) : 0;
 | 
						|
$selectedYear = isset($_POST['year']) && !empty($_POST['year']) ? trim($_POST['year']) : null;
 | 
						|
$selectedStudent = isset($_POST['student']) && !empty($_POST['student']) ? intval($_POST['student']) : 0;
 | 
						|
 | 
						|
$userId = api_get_user_id();
 | 
						|
 | 
						|
$sessions = $courses = $months = $students = [0 => get_lang('Select')];
 | 
						|
 | 
						|
if (api_is_student_boss()) {
 | 
						|
    $userGroup = new UserGroup();
 | 
						|
    $userList = $userGroup->getGroupUsersByUser($userId);
 | 
						|
    $sessionsList = SessionManager::getSessionsFollowedForGroupAdmin($userId);
 | 
						|
} else {
 | 
						|
    $sessionsList = SessionManager::getSessionsCoachedByUser($userId, false, api_is_platform_admin());
 | 
						|
}
 | 
						|
 | 
						|
foreach ($sessionsList as $session) {
 | 
						|
    $sessions[$session['id']] = $session['name'];
 | 
						|
}
 | 
						|
 | 
						|
if ($selectedSession > 0) {
 | 
						|
    if (!SessionManager::isValidId($selectedSession)) {
 | 
						|
        Session::write('reportErrorMessage', get_lang('NoSession'));
 | 
						|
 | 
						|
        header("Location: $selfUrl");
 | 
						|
        exit;
 | 
						|
    }
 | 
						|
 | 
						|
    $coursesList = SessionManager::get_course_list_by_session_id($selectedSession);
 | 
						|
 | 
						|
    if (is_array($coursesList)) {
 | 
						|
        foreach ($coursesList as &$course) {
 | 
						|
            $course['real_id'] = $course['id'];
 | 
						|
        }
 | 
						|
    }
 | 
						|
} else {
 | 
						|
    if (api_is_student_boss()) {
 | 
						|
        $coursesList = CourseManager::getCoursesFollowedByGroupAdmin($userId);
 | 
						|
    } else {
 | 
						|
        $coursesList = CourseManager::get_courses_list_by_user_id($userId, false, true);
 | 
						|
 | 
						|
        if (is_array($coursesList)) {
 | 
						|
            foreach ($coursesList as &$course) {
 | 
						|
                $courseInfo = api_get_course_info_by_id($course['real_id']);
 | 
						|
 | 
						|
                $course = array_merge($course, $courseInfo);
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
foreach ($coursesList as $course) {
 | 
						|
    if (isset($course['real_id'])) {
 | 
						|
        $courses[$course['real_id']] = $course['title'];
 | 
						|
    } else {
 | 
						|
        $courses[$course['id']] = $course['title'];
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
for ($key = 1; $key <= 12; $key++) {
 | 
						|
    $months[$key] = sprintf("%02d", $key);
 | 
						|
}
 | 
						|
 | 
						|
$exportAllLink = null;
 | 
						|
$certificateStudents = array();
 | 
						|
 | 
						|
$searchSessionAndCourse = $selectedSession > 0 && $selectedCourse > 0;
 | 
						|
$searchCourseOnly = $selectedSession <= 0 && $selectedCourse > 0;
 | 
						|
$searchStudentOnly = $selectedStudent > 0;
 | 
						|
 | 
						|
if ($searchSessionAndCourse || $searchCourseOnly) {
 | 
						|
    $selectedCourseInfo = api_get_course_info_by_id($selectedCourse);
 | 
						|
 | 
						|
    if (empty($selectedCourseInfo)) {
 | 
						|
        Session::write('reportErrorMessage', get_lang('NoCourse'));
 | 
						|
 | 
						|
        header("Location: $selfUrl");
 | 
						|
        exit;
 | 
						|
    }
 | 
						|
 | 
						|
    $gradebookCategories = Category::load(null, null, $selectedCourseInfo['code'], null, false, $selectedSession);
 | 
						|
 | 
						|
    $gradebook = null;
 | 
						|
 | 
						|
    if (!empty($gradebookCategories)) {
 | 
						|
        $gradebook = current($gradebookCategories);
 | 
						|
    }
 | 
						|
 | 
						|
    if (!is_null($gradebook)) {
 | 
						|
        $exportAllLink = api_get_path(WEB_CODE_PATH) . "gradebook/gradebook_display_certificate.php?";
 | 
						|
        $exportAllLink .= http_build_query(array(
 | 
						|
            "action" => "export_all_certificates",
 | 
						|
            "cidReq" => $selectedCourseInfo['code'],
 | 
						|
            "id_session" => 0,
 | 
						|
            "gidReq" => 0,
 | 
						|
            "cat_id" => $gradebook->get_id()
 | 
						|
        ));
 | 
						|
 | 
						|
        $sessionName = api_get_session_name($selectedSession);
 | 
						|
        $courseName = api_get_course_info($selectedCourseInfo['code'])['title'];
 | 
						|
 | 
						|
        $studentList = GradebookUtils::get_list_users_certificates($gradebook->get_id());
 | 
						|
 | 
						|
        $certificateStudents = array();
 | 
						|
 | 
						|
        if (is_array($studentList) && !empty($studentList)) {
 | 
						|
            foreach ($studentList as $student) {
 | 
						|
                if (api_is_student_boss() && !in_array($student['user_id'], $userList)) {
 | 
						|
                    continue;
 | 
						|
                }
 | 
						|
 | 
						|
                $certificateStudent = array(
 | 
						|
                    'fullName' => api_get_person_name($student['firstname'], $student['lastname']),
 | 
						|
                    'sessionName' => $sessionName,
 | 
						|
                    'courseName' => $courseName,
 | 
						|
                    'certificates' => array()
 | 
						|
                );
 | 
						|
 | 
						|
                $studentCertificates = GradebookUtils::get_list_gradebook_certificates_by_user_id(
 | 
						|
                    $student['user_id'],
 | 
						|
                    $gradebook->get_id()
 | 
						|
                );
 | 
						|
 | 
						|
                if (!is_array($studentCertificates) || empty($studentCertificates)) {
 | 
						|
                    continue;
 | 
						|
                }
 | 
						|
 | 
						|
                foreach ($studentCertificates as $certificate) {
 | 
						|
                    $creationDate = new DateTime($certificate['created_at']);
 | 
						|
                    $creationMonth = $creationDate->format('m');
 | 
						|
                    $creationYear = $creationDate->format('Y');
 | 
						|
                    $creationMonthYear = $creationDate->format('m Y');
 | 
						|
 | 
						|
                    if ($selectedMonth > 0 && empty($selectedYear)) {
 | 
						|
                        if ($creationMonth != $selectedMonth) {
 | 
						|
                            continue;
 | 
						|
                        }
 | 
						|
                    } elseif ($selectedMonth <= 0 && !empty($selectedYear)) {
 | 
						|
                        if ($creationYear != $selectedYear) {
 | 
						|
                            continue;
 | 
						|
                        }
 | 
						|
                    } elseif ($selectedMonth > 0 && !empty($selectedYear)) {
 | 
						|
                        if ($creationMonthYear != sprintf("%02d %s", $selectedMonth, $selectedYear)) {
 | 
						|
                            continue;
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
 | 
						|
                    $certificateStudent['certificates'][] = array(
 | 
						|
                        'createdAt' => api_convert_and_format_date($certificate['created_at']),
 | 
						|
                        'id' => $certificate['id']
 | 
						|
                    );
 | 
						|
                }
 | 
						|
 | 
						|
                if (count($certificateStudent['certificates']) > 0) {
 | 
						|
                    $certificateStudents[] = $certificateStudent;
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
} elseif ($searchStudentOnly) {
 | 
						|
    $selectedStudentInfo = api_get_user_info($selectedStudent);
 | 
						|
 | 
						|
    if (empty($selectedStudentInfo)) {
 | 
						|
        Session::write('reportErrorMessage', get_lang('NoUser'));
 | 
						|
 | 
						|
        header('Location: '.$selfUrl);
 | 
						|
        exit;
 | 
						|
    }
 | 
						|
 | 
						|
    $sessionList = SessionManager::getSessionsFollowedByUser($selectedStudent);
 | 
						|
 | 
						|
    foreach ($sessionList as $session) {
 | 
						|
        $sessionCourseList = SessionManager::get_course_list_by_session_id($session['id']);
 | 
						|
 | 
						|
        foreach ($sessionCourseList as $sessionCourse) {
 | 
						|
            $gradebookCategories = Category::load(null, null, $sessionCourse['code'], null, false, $session['id']);
 | 
						|
 | 
						|
            $gradebook = null;
 | 
						|
 | 
						|
            if (!empty($gradebookCategories)) {
 | 
						|
                $gradebook = current($gradebookCategories);
 | 
						|
            }
 | 
						|
 | 
						|
            if (!is_null($gradebook)) {
 | 
						|
                $sessionName = $session['name'];
 | 
						|
                $courseName = $sessionCourse['title'];
 | 
						|
 | 
						|
                $certificateStudent = [
 | 
						|
                    'fullName' => $selectedStudentInfo['complete_name'],
 | 
						|
                    'sessionName' => $sessionName,
 | 
						|
                    'courseName' => $courseName,
 | 
						|
                    'certificates' => []
 | 
						|
                ];
 | 
						|
 | 
						|
                $studentCertificates = GradebookUtils::get_list_gradebook_certificates_by_user_id(
 | 
						|
                    $selectedStudent,
 | 
						|
                    $gradebook->get_id()
 | 
						|
                );
 | 
						|
 | 
						|
                if (!is_array($studentCertificates) || empty($studentCertificates)) {
 | 
						|
                    continue;
 | 
						|
                }
 | 
						|
 | 
						|
                foreach ($studentCertificates as $certificate) {
 | 
						|
                    $certificateStudent['certificates'][] = array(
 | 
						|
                        'createdAt' => api_convert_and_format_date($certificate['created_at']),
 | 
						|
                        'id' => $certificate['id']
 | 
						|
                    );
 | 
						|
                }
 | 
						|
 | 
						|
                if (count($certificateStudent['certificates']) > 0) {
 | 
						|
                    $certificateStudents[] = $certificateStudent;
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
/* View */
 | 
						|
$template = new Template(get_lang('GradebookListOfStudentsCertificates'));
 | 
						|
 | 
						|
if (Session::has('reportErrorMessage')) {
 | 
						|
    $template->assign('errorMessage', Session::read('reportErrorMessage'));
 | 
						|
}
 | 
						|
 | 
						|
$searchBySessionCourseDateForm = new FormValidator(
 | 
						|
    'certificate_report_form',
 | 
						|
    'post',
 | 
						|
    api_get_path(WEB_CODE_PATH) . 'gradebook/certificate_report.php'
 | 
						|
);
 | 
						|
$searchBySessionCourseDateForm->addSelect('session', get_lang('Sessions'), $sessions, ['id' => 'session']);
 | 
						|
$searchBySessionCourseDateForm->addSelect('course', get_lang('Courses'), $courses, ['id' => 'course']);
 | 
						|
$searchBySessionCourseDateForm->addGroup(
 | 
						|
    [
 | 
						|
        $searchBySessionCourseDateForm->createElement('select', 'month', null, $months, ['id' => 'month']),
 | 
						|
        $searchBySessionCourseDateForm->createElement(
 | 
						|
            'text',
 | 
						|
            'year',
 | 
						|
            null,
 | 
						|
            ['id' => 'year', 'placeholder' => get_lang('Year')]
 | 
						|
        )
 | 
						|
    ],
 | 
						|
    null,
 | 
						|
    get_lang('Date')
 | 
						|
);
 | 
						|
$searchBySessionCourseDateForm->addButtonSearch();
 | 
						|
$searchBySessionCourseDateForm->setDefaults([
 | 
						|
    'session' => $selectedSession,
 | 
						|
    'course' => $selectedCourse,
 | 
						|
    'month' => $selectedMonth,
 | 
						|
    'year' => $selectedYear
 | 
						|
]);
 | 
						|
 | 
						|
if (api_is_student_boss()) {
 | 
						|
    foreach ($userList as $studentId) {
 | 
						|
        $students[$studentId] = api_get_user_info($studentId)['complete_name_with_username'];
 | 
						|
    }
 | 
						|
 | 
						|
    $searchByStudentForm = new FormValidator(
 | 
						|
        'certificate_report_form',
 | 
						|
        'post',
 | 
						|
        api_get_path(WEB_CODE_PATH) . 'gradebook/certificate_report.php'
 | 
						|
    );
 | 
						|
    $searchByStudentForm->addSelect('student', get_lang('Students'), $students, ['id' => 'student']);
 | 
						|
    $searchByStudentForm->addButtonSearch();
 | 
						|
    $searchByStudentForm->setDefaults([
 | 
						|
        'student' => $selectedStudent
 | 
						|
    ]);
 | 
						|
 | 
						|
    $template->assign('searchByStudentForm', $searchByStudentForm->returnForm());
 | 
						|
}
 | 
						|
 | 
						|
$template->assign('searchBySessionCourseDateForm', $searchBySessionCourseDateForm->returnForm());
 | 
						|
$template->assign('sessions', $sessions);
 | 
						|
$template->assign('courses', $courses);
 | 
						|
$template->assign('months', $months);
 | 
						|
$template->assign('exportAllLink', $exportAllLink);
 | 
						|
$template->assign('certificateStudents', $certificateStudents);
 | 
						|
$content = $template->fetch("default/gradebook/certificate_report.tpl");
 | 
						|
 | 
						|
$template->assign('content', $content);
 | 
						|
 | 
						|
$template->display_one_col_template();
 | 
						|
 | 
						|
Session::erase('reportErrorMessage');
 | 
						|
 |