Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 4.1.x will end 13 November 2023 (12 months).
  • Bug fixes for security issues in 4.1.x will end 10 November 2025 (36 months).
  • PHP version: minimum PHP 7.4.0 Note: minimum PHP version has increased since Moodle 4.0. PHP 8.0.x is supported too.
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

/**
 * This page prints a review of a particular question attempt.
 * This page is expected to only be used in a popup window.
 *
 * @package   mod_quiz
 * @copyright 1999 onwards Martin Dougiamas  {@link http://moodle.com}
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */


require_once(__DIR__ . '/../../config.php');
require_once('locallib.php');

$attemptid = required_param('attempt', PARAM_INT);
$slot = required_param('slot', PARAM_INT);
$seq = optional_param('step', null, PARAM_INT);
$cmid = optional_param('cmid', null, PARAM_INT);

$baseurl = new moodle_url('/mod/quiz/reviewquestion.php',
< array('attempt' => $attemptid, 'slot' => $slot));
> ['attempt' => $attemptid, 'slot' => $slot]);
$currenturl = new moodle_url($baseurl); if (!is_null($seq)) { $currenturl->param('step', $seq); } $PAGE->set_url($currenturl); $attemptobj = quiz_create_attempt_handling_errors($attemptid, $cmid); $attemptobj->preload_all_attempt_step_users(); // Check login. require_login($attemptobj->get_course(), false, $attemptobj->get_cm()); $attemptobj->check_review_capability();
< $student = $DB->get_record('user', array('id' => $attemptobj->get_userid()));
> $student = $DB->get_record('user', ['id' => $attemptobj->get_userid()]);
$accessmanager = $attemptobj->get_access_manager(time()); $options = $attemptobj->get_display_options(true); $PAGE->set_pagelayout('popup');
< $PAGE->set_title(get_string('reviewofquestion', 'quiz', array(
> $PAGE->set_title(get_string('reviewofquestion', 'quiz', [
'question' => format_string($attemptobj->get_question_name($slot)),
< 'quiz' => format_string($attemptobj->get_quiz_name()), 'user' => fullname($student))));
> 'quiz' => format_string($attemptobj->get_quiz_name()), 'user' => fullname($student)]));
$PAGE->set_heading($attemptobj->get_course()->fullname); $output = $PAGE->get_renderer('mod_quiz'); // Check permissions - warning there is similar code in review.php and // quiz_attempt::check_file_access. If you change on, change them all. if ($attemptobj->is_own_attempt()) { if (!$attemptobj->is_finished()) { echo $output->review_question_not_allowed($attemptobj, get_string('cannotreviewopen', 'quiz')); die(); } else if (!$options->attempt) { echo $output->review_question_not_allowed($attemptobj, $attemptobj->cannot_review_message()); die(); } } else if (!$attemptobj->is_review_allowed()) {
< throw new moodle_quiz_exception($attemptobj->get_quizobj(), 'noreviewattempt');
> throw new moodle_exception('noreviewattempt', 'quiz', $attemptobj->view_url());
} // Prepare summary informat about this question attempt.
< $summarydata = array();
> $summarydata = [];
// Student name. $userpicture = new user_picture($student); $userpicture->courseid = $attemptobj->get_courseid();
< $summarydata['user'] = array(
> $summarydata['user'] = [
'title' => $userpicture,
< 'content' => new action_link(new moodle_url('/user/view.php', array( < 'id' => $student->id, 'course' => $attemptobj->get_courseid())),
> 'content' => new action_link(new moodle_url('/user/view.php', [ > 'id' => $student->id, 'course' => $attemptobj->get_courseid()]),
fullname($student, true)),
< );
> ];
// Quiz name.
< $summarydata['quizname'] = array(
> $summarydata['quizname'] = [
'title' => get_string('modulename', 'quiz'), 'content' => format_string($attemptobj->get_quiz_name()),
< );
> ];
// Question name.
< $summarydata['questionname'] = array(
> $summarydata['questionname'] = [
'title' => get_string('question', 'quiz'), 'content' => $attemptobj->get_question_name($slot),
< );
> ];
// Other attempts at the quiz. if ($attemptobj->has_capability('mod/quiz:viewreports')) { $otherattemptsurl = clone($baseurl); $otherattemptsurl->param('slot', $attemptobj->get_original_slot($slot)); $attemptlist = $attemptobj->links_to_other_attempts($otherattemptsurl); if ($attemptlist) {
< $summarydata['attemptlist'] = array(
> $summarydata['attemptlist'] = [
'title' => get_string('attempts', 'quiz'), 'content' => $attemptlist,
< );
> ];
} } // Timestamp of this action. $timestamp = $attemptobj->get_question_action_time($slot); if ($timestamp) {
< $summarydata['timestamp'] = array(
> $summarydata['timestamp'] = [
'title' => get_string('completedon', 'quiz'), 'content' => userdate($timestamp),
< );
> ];
} echo $output->review_question_page($attemptobj, $slot, $seq, $attemptobj->get_display_options(true), $summarydata);