|
@@ -5,6 +5,8 @@
|
|
|
* @author Angel Fernando Quiroz Campos <angel.quiroz@beeznest.com>
|
|
|
* @package chamilo.gradebook
|
|
|
*/
|
|
|
+use \ChamiloSession as Session;
|
|
|
+
|
|
|
$language_file = array('gradebook', 'exercice');
|
|
|
$cidReset = true;
|
|
|
|
|
@@ -28,6 +30,13 @@ $userId = api_get_user_id();
|
|
|
$sessions = SessionManager::getSessionsCoachedByUser($userId);
|
|
|
|
|
|
if ($selectedSession > 0) {
|
|
|
+ if (!SessionManager::isValidId($selectedSession)) {
|
|
|
+ Session::write('reportErrorMessage', get_lang('NoSession'));
|
|
|
+
|
|
|
+ header("Location: $selfUrl");
|
|
|
+ exit;
|
|
|
+ }
|
|
|
+
|
|
|
$courses = SessionManager::get_course_list_by_session_id($selectedSession);
|
|
|
|
|
|
if (is_array($courses)) {
|
|
@@ -65,67 +74,80 @@ $searchCourseOnly = $selectedSession <= 0 && $selectedCourse > 0;
|
|
|
if ($searchSessionAndCourse || $searchCourseOnly) {
|
|
|
$selectedCourseInfo = api_get_course_info_by_id($selectedCourse);
|
|
|
|
|
|
- $gradebookCategories = Category::load(null, null, $selectedCourseInfo['code'], null, false, $selectedSession);
|
|
|
-
|
|
|
- $gradebook = current($gradebookCategories);
|
|
|
+ if (empty($selectedCourseInfo)) {
|
|
|
+ Session::write('reportErrorMessage', get_lang('NoCourse'));
|
|
|
|
|
|
- $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()
|
|
|
- ));
|
|
|
+ header("Location: $selfUrl");
|
|
|
+ exit;
|
|
|
+ }
|
|
|
|
|
|
- $studentList = GradebookUtils::get_list_users_certificates($gradebook->get_id());
|
|
|
+ $gradebookCategories = Category::load(null, null, $selectedCourseInfo['code'], null, false, $selectedSession);
|
|
|
|
|
|
- $certificateStudents = array();
|
|
|
+ $gradebook = null;
|
|
|
|
|
|
- if (is_array($studentList)) {
|
|
|
- foreach ($studentList as $student) {
|
|
|
- $certificateStudent = array(
|
|
|
- 'fullName' => api_get_person_name($student['firstname'], $student['lastname']),
|
|
|
- 'certificates' => array()
|
|
|
- );
|
|
|
+ if (!empty($gradebookCategories)) {
|
|
|
+ $gradebook = current($gradebookCategories);
|
|
|
+ }
|
|
|
|
|
|
- $studentCertificates = GradebookUtils::get_list_gradebook_certificates_by_user_id(
|
|
|
- $student['user_id'],
|
|
|
- $gradebook->get_id()
|
|
|
- );
|
|
|
+ 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()
|
|
|
+ ));
|
|
|
+
|
|
|
+ $studentList = GradebookUtils::get_list_users_certificates($gradebook->get_id());
|
|
|
+
|
|
|
+ $certificateStudents = array();
|
|
|
+
|
|
|
+ if (is_array($studentList) && !empty($studentList)) {
|
|
|
+ foreach ($studentList as $student) {
|
|
|
+ $certificateStudent = array(
|
|
|
+ 'fullName' => api_get_person_name($student['firstname'], $student['lastname']),
|
|
|
+ 'certificates' => array()
|
|
|
+ );
|
|
|
|
|
|
- if (!is_array($studentCertificates)) {
|
|
|
- continue;
|
|
|
- }
|
|
|
+ $studentCertificates = GradebookUtils::get_list_gradebook_certificates_by_user_id(
|
|
|
+ $student['user_id'],
|
|
|
+ $gradebook->get_id()
|
|
|
+ );
|
|
|
|
|
|
- foreach ($studentCertificates as $certificate) {
|
|
|
- $creationDate = new DateTime($certificate['created_at']);
|
|
|
- $creationMonth = $creationDate->format('m');
|
|
|
- $creationYear = $creationDate->format('Y');
|
|
|
- $creationMonthYear = $creationDate->format('m Y');
|
|
|
+ if (!is_array($studentCertificates) || empty($studentCertificates)) {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
|
|
|
- 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("%d %s", $selectedMonth, $selectedYear)) {
|
|
|
- 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("%d %s", $selectedMonth, $selectedYear)) {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
}
|
|
|
- }
|
|
|
|
|
|
- $certificateStudent['certificates'][] = array(
|
|
|
- 'createdAt' => api_convert_and_format_date($certificate['created_at']),
|
|
|
- 'id' => $certificate['id']
|
|
|
- );
|
|
|
- }
|
|
|
+ $certificateStudent['certificates'][] = array(
|
|
|
+ 'createdAt' => api_convert_and_format_date($certificate['created_at']),
|
|
|
+ 'id' => $certificate['id']
|
|
|
+ );
|
|
|
+ }
|
|
|
|
|
|
- if (count($certificateStudent['certificates']) > 0) {
|
|
|
- $certificateStudents[] = $certificateStudent;
|
|
|
+ if (count($certificateStudent['certificates']) > 0) {
|
|
|
+ $certificateStudents[] = $certificateStudent;
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -134,6 +156,10 @@ if ($searchSessionAndCourse || $searchCourseOnly) {
|
|
|
|
|
|
$template = new Template(get_lang('GradebookListOfStudentsCertificates'));
|
|
|
|
|
|
+if (Session::has('reportErrorMessage')) {
|
|
|
+ $template->assign('errorMessage', Session::read('reportErrorMessage'));
|
|
|
+}
|
|
|
+
|
|
|
$template->assign('selectedSession', $selectedSession);
|
|
|
$template->assign('selectedCourse', $selectedCourse);
|
|
|
$template->assign('selectedMonth', $selectedMonth);
|
|
@@ -148,3 +174,5 @@ $content = $template->fetch("default/gradebook/certificate_report.tpl");
|
|
|
$template->assign('content', $content);
|
|
|
|
|
|
$template->display_one_col_template();
|
|
|
+
|
|
|
+Session::erase('reportErrorMessage');
|