read($exerciseId); if (!$result) { api_not_allowed(true); } $sessionId = api_get_session_id(); $courseCode = api_get_course_id(); $courseId = api_get_course_int_id(); if (empty($sessionId)) { $students = CourseManager::get_student_list_from_course_code($courseCode, false); } else { $students = CourseManager::get_student_list_from_course_code($courseCode, true, $sessionId); } $count_students = count($students); $questionList = $objExercise->getQuestionForTeacher(0, $objExercise->getQuestionCount()); $data = []; // Question title # of students who tool it Lowest score Average Highest score Maximum score $headers = [ get_lang('Question'), get_lang('QuestionType'), get_lang('NumberStudentWhoSelectedIt'), get_lang('LowestScore'), get_lang('AverageScore'), get_lang('HighestScore'), get_lang('Weighting'), ]; if (!empty($questionList)) { foreach ($questionList as $question_id) { $questionObj = Question::read($question_id); $exerciseStats = ExerciseLib::get_student_stats_by_question( $question_id, $exerciseId, $courseId, $sessionId, true ); $count_users = ExerciseLib::get_number_students_question_with_answer_count( $question_id, $exerciseId, $courseCode, $sessionId, $questionObj->type ); $data[$question_id]['name'] = cut($questionObj->question, 100); $data[$question_id]['type'] = $questionObj->get_question_type_name(); $percentage = 0; if ($count_students) { $percentage = $count_users / $count_students * 100; } if ($exportXls) { $data[$question_id]['students_who_try_exercise'] = $count_users.' / '.$count_students.' ('.$percentage.'%)'; } else { $data[$question_id]['students_who_try_exercise'] = Display::bar_progress( $percentage, false, $count_users.' / '.$count_students ); } $data[$question_id]['lowest_score'] = round($exerciseStats['min'], 2); $data[$question_id]['average_score'] = round($exerciseStats['average'], 2); $data[$question_id]['highest_score'] = round($exerciseStats['max'], 2); $data[$question_id]['max_score'] = round($questionObj->weighting, 2); } } $table = new HTML_Table(['class' => 'table table-hover table-striped data_table']); $row = 0; $column = 0; foreach ($headers as $header) { $table->setHeaderContents($row, $column, $header); $column++; } if ($exportXls) { $tableXls1[] = $headers; } $row++; foreach ($data as $row_table) { $column = 0; foreach ($row_table as $key => $cell) { $table->setCellContents($row, $column, $cell); $table->updateCellAttributes($row, $column, 'align="center"'); if ($exportXls) { $row_table[$key] = strip_tags($cell); } $column++; } $table->updateRowAttributes($row, $row % 2 ? 'class="row_even"' : 'class="row_odd"', true); if ($exportXls) { $tableXls1[] = $row_table; } $row++; } $content = $table->toHtml(); // Format B $headers = [ get_lang('Question'), get_lang('Answer'), get_lang('Correct'), get_lang('NumberStudentWhoSelectedIt'), ]; $data = []; if (!empty($questionList)) { $id = 0; foreach ($questionList as $question_id) { $questionObj = Question::read($question_id); $exerciseStats = ExerciseLib::get_student_stats_by_question( $question_id, $exerciseId, $courseId, $sessionId, true ); $answer = new Answer($question_id); $answer_count = $answer->selectNbrAnswers(); for ($answer_id = 1; $answer_id <= $answer_count; $answer_id++) { $answer_info = $answer->selectAnswer($answer_id); $is_correct = $answer->isCorrect($answer_id); $correct_answer = $is_correct == 1 ? get_lang('Yes') : get_lang('No'); $real_answer_id = $answer->selectAutoId($answer_id); // Overwriting values depending of the question switch ($questionObj->type) { case FILL_IN_BLANKS: case FILL_IN_BLANKS_COMBINATION: $answer_info_db = $answer_info; $answer_info = substr($answer_info, 0, strpos($answer_info, '::')); $correct_answer = $is_correct; $answers = $objExercise->fill_in_blank_answer_to_array($answer_info); $counter = 0; foreach ($answers as $answer_item) { if (0 == $counter) { $data[$id]['name'] = cut($questionObj->question, 100); } else { $data[$id]['name'] = '-'; } $data[$id]['answer'] = $answer_item; $answer_item = api_substr($answer_item, 1); $answer_item = api_substr($answer_item, 0, api_strlen($answer_item) - 1); $data[$id]['answer'] = $answer_item; $data[$id]['correct'] = '-'; $count = ExerciseLib::getNumberStudentsFillBlanksAnswerCount($question_id, $exerciseId); $count = isset($count[$counter]) ? $count[$counter] : 0; $percentage = 0; if (!empty($count_students)) { $percentage = $count / $count_students * 100; } if ($exportXls) { $data[$id]['attempts'] = $count.' / '.$count_students.' ('.$percentage.'%)'; } else { $data[$id]['attempts'] = Display::bar_progress( $percentage, false, $count.' / '.$count_students ); } $id++; $counter++; } break; case MATCHING: case MATCHING_DRAGGABLE: if ($is_correct == 0) { if ($answer_id == 1) { $data[$id]['name'] = cut($questionObj->question, 100); } else { $data[$id]['name'] = '-'; } $correct = ''; for ($i = 1; $i <= $answer_count; $i++) { $is_correct_i = $answer->isCorrect($i); if ($is_correct_i != 0 && $is_correct_i == $answer_id) { $correct = $answer->selectAnswer($i); break; } } $data[$id]['answer'] = $correct; $data[$id]['correct'] = $answer_info; $count = ExerciseLib::get_number_students_answer_count( $answer_id, $question_id, $exerciseId, $courseId, $sessionId, MATCHING ); $percentage = 0; if (!empty($count_students)) { $percentage = $count / $count_students * 100; } if ($exportXls) { $data[$id]['attempts'] = $count.' / '.$count_students.' ('.$percentage.'%)'; } else { $data[$id]['attempts'] = Display::bar_progress( $percentage, false, $count.' / '.$count_students ); } } break; case HOT_SPOT: case HOT_SPOT_COMBINATION: if ($answer_id == 1) { $data[$id]['name'] = cut($questionObj->question, 100); } else { $data[$id]['name'] = '-'; } $data[$id]['answer'] = $answer_info; $data[$id]['correct'] = '-'; $count = ExerciseLib::get_number_students_answer_hotspot_count( $answer_id, $question_id, $exerciseId, $courseCode, $sessionId ); $percentage = 0; if (!empty($count_students)) { $percentage = $count / $count_students * 100; } if ($exportXls) { $data[$id]['attempts'] = $count.' / '.$count_students.' ('.$percentage.'%)'; } else { $data[$id]['attempts'] = Display::bar_progress( $percentage, false, $count.' / '.$count_students ); } break; default: if ($answer_id == 1) { $data[$id]['name'] = cut($questionObj->question, 100); } else { $data[$id]['name'] = '-'; } $data[$id]['answer'] = $answer_info; $data[$id]['correct'] = $correct_answer; $count = ExerciseLib::get_number_students_answer_count( $real_answer_id, $question_id, $exerciseId, $courseId, $sessionId ); $percentage = 0; if (!empty($count_students)) { $percentage = $count / $count_students * 100; } if ($exportXls) { $data[$id]['attempts'] = $count.' / '.$count_students.' ('.$percentage.'%)'; } else { $data[$id]['attempts'] = Display::bar_progress( $percentage, false, $count.' / '.$count_students ); } } $id++; } } } // Format A table $table = new HTML_Table(['class' => 'table table-hover table-striped data_table']); $row = 0; $column = 0; foreach ($headers as $header) { $table->setHeaderContents($row, $column, $header); $column++; } if ($exportXls) { $tableXls1[] = []; // it adds an empty line after the first table $tableXls2[] = $headers; } $row++; foreach ($data as $row_table) { $column = 0; foreach ($row_table as $key => $cell) { $table->setCellContents($row, $column, $cell); $table->updateCellAttributes($row, $column, 'align="center"'); if ($exportXls) { $row_table[$key] = strip_tags($cell); } $column++; } $table->updateRowAttributes($row, $row % 2 ? 'class="row_even"' : 'class="row_odd"', true); if ($exportXls) { $tableXls2[] = $row_table; } $row++; } $content .= $table->toHtml(); $exportPdf = isset($_GET['export_pdf']) && !empty($_GET['export_pdf']) ? (int) $_GET['export_pdf'] : 0; if ($exportPdf) { $fileName = get_lang('Report').'_'.api_get_course_id().'_'.api_get_local_time(); $params = [ 'filename' => $fileName, 'pdf_title' => $objExercise->selectTitle(true).'
'.get_lang('ReportByQuestion'), 'pdf_description' => get_lang('Report'), 'format' => 'A4', 'orientation' => 'P', ]; Export::export_html_to_pdf($content, $params); exit; } if ($exportXls) { $fileName = get_lang('Report').'_'.api_get_course_id().'_'.api_get_local_time(); $tableXls = array_merge($tableXls1, $tableXls2); Export::arrayToXls($tableXls, $fileName); exit; } $interbreadcrumb[] = [ "url" => "exercise.php?".api_get_cidreq(), "name" => get_lang('Exercises'), ]; $interbreadcrumb[] = [ 'url' => "admin.php?exerciseId=$exerciseId&".api_get_cidreq(), 'name' => $objExercise->selectTitle(true), ]; $tpl = new Template(get_lang('ReportByQuestion')); $actions = ''. Display::return_icon( 'back.png', get_lang('GoBackToQuestionList'), '', ICON_SIZE_MEDIUM ) .''; $actions .= Display::url( Display::return_icon('pdf.png', get_lang('ExportToPDF'), [], ICON_SIZE_MEDIUM), 'stats.php?exerciseId='.$exerciseId.'&export_pdf=1&'.api_get_cidreq() ); $actions .= Display::url( Display::return_icon('excel.png', get_lang('ExportAsXLS'), [], ICON_SIZE_MEDIUM), 'stats.php?exerciseId='.$exerciseId.'&export_xls=1&'.api_get_cidreq() ); $actions = Display::div($actions, ['class' => 'actions']); $content = $actions.$content; $tpl->assign('content', $content); $tpl->display_one_col_template();