MDL-26045 fix invalid sql join when separate group mode enabled
[moodle.git] / mod / quiz / index.php
1 <?php
2 /**
3  * This page lists all the instances of quiz in a particular course
4  *
5  * @author Martin Dougiamas and many others.
6  * @license http://www.gnu.org/copyleft/gpl.html GNU Public License
7  * @package quiz
8  */
9     require_once("../../config.php");
10     require_once("locallib.php");
12     $id = required_param('id', PARAM_INT);
13     $PAGE->set_url('/mod/quiz/index.php', array('id'=>$id));
14     if (!$course = $DB->get_record('course', array('id' => $id))) {
15         print_error('invalidcourseid');
16     }
17     $coursecontext = get_context_instance(CONTEXT_COURSE, $id);
18     require_login($course->id);
19     $PAGE->set_pagelayout('incourse');
21     add_to_log($course->id, "quiz", "view all", "index.php?id=$course->id", "");
23 // Print the header
24     $strquizzes = get_string("modulenameplural", "quiz");
25     $streditquestions = '';
26     $editqcontexts = new question_edit_contexts($coursecontext);
27     if ($editqcontexts->have_one_edit_tab_cap('questions')) {
28         $streditquestions =
29                 "<form target=\"_parent\" method=\"get\" action=\"$CFG->wwwroot/question/edit.php\">
30                    <div>
31                    <input type=\"hidden\" name=\"courseid\" value=\"$course->id\" />
32                    <input type=\"submit\" value=\"".get_string("editquestions", "quiz")."\" />
33                    </div>
34                  </form>";
35     }
36     $PAGE->navbar->add($strquizzes);
37     $PAGE->set_title($strquizzes);
38     $PAGE->set_button($streditquestions);
39     $PAGE->set_heading($course->fullname);
40     echo $OUTPUT->header();
42 // Get all the appropriate data
43     if (!$quizzes = get_all_instances_in_course("quiz", $course)) {
44         notice(get_string('thereareno', 'moodle', $strquizzes), "../../course/view.php?id=$course->id");
45         die;
46     }
47     $sections = get_all_sections($course->id);
49 // Check if we need the closing date header
50     $showclosingheader = false;
51     $showfeedback = false;
52     foreach ($quizzes as $quiz) {
53         if ($quiz->timeclose!=0) {
54             $showclosingheader=true;
55         }
56         if (quiz_has_feedback($quiz)) {
57             $showfeedback=true;
58         }
59         if($showclosingheader && $showfeedback) {
60             break;
61         }
62     }
64 // Configure table for displaying the list of instances.
65     $headings = array(get_string('name'));
66     $align = array('left');
68     if ($showclosingheader) {
69         array_push($headings, get_string('quizcloses', 'quiz'));
70         array_push($align, 'left');
71     }
73     array_unshift($headings, get_string('sectionname', 'format_'.$course->format));
74     array_unshift($align, 'center');
76     $showing = '';  // default
78     if (has_capability('mod/quiz:viewreports', $coursecontext)) {
79         array_push($headings, get_string('attempts', 'quiz'));
80         array_push($align, 'left');
81         $showing = 'stats';
82     } else if (has_any_capability(array('mod/quiz:reviewmyattempts', 'mod/quiz:attempt'), $coursecontext)) {
83         array_push($headings, get_string('grade', 'quiz'));
84         array_push($align, 'left');
85         if ($showfeedback) {
86             array_push($headings, get_string('feedback', 'quiz'));
87             array_push($align, 'left');
88         }
89         $showing = 'scores';  // default
91         $scores = $DB->get_records_sql_menu('
92                 SELECT qg.quiz, qg.grade
93                 FROM {quiz_grades} qg
94                 JOIN {quiz} q ON q.id = qg.quiz
95                 WHERE q.course = ?',
96                 $course->id);
97     }
99     $table = new html_table();
100     $table->head = $headings;
101     $table->align = $align;
103 /// Populate the table with the list of instances.
104     $currentsection = '';
105     foreach ($quizzes as $quiz) {
106         $cm = get_coursemodule_from_instance('quiz', $quiz->id);
107         $context = get_context_instance(CONTEXT_MODULE, $cm->id);
108         $data = array();
110         // Section number if necessary.
111         $strsection = '';
112         if ($quiz->section != $currentsection) {
113             if ($quiz->section) {
114                 $strsection = $quiz->section;
115                 $strsection = get_section_name($course, $sections[$quiz->section]);
116             }
117             if ($currentsection) {
118                 $learningtable->data[] = 'hr';
119             }
120             $currentsection = $quiz->section;
121         }
122         $data[] = $strsection;
124         // Link to the instance.
125         $class = '';
126         if (!$quiz->visible) {
127             $class = ' class="dimmed"';
128         }
129         $data[] = "<a$class href=\"view.php?id=$quiz->coursemodule\">" . format_string($quiz->name, true) . '</a>';
131         // Close date.
132         if ($quiz->timeclose) {
133             $data[] = userdate($quiz->timeclose);
134         } else if ($showclosingheader) {
135             $data[] = '';
136         }
138         if ($showing == 'stats') {
139             // The $quiz objects returned by get_all_instances_in_course have the necessary $cm
140             // fields set to make the following call work.
141             $data[] = quiz_attempt_summary_link_to_reports($quiz, $cm, $context);
143         } else if ($showing == 'scores') {
144             // Grade and feedback.
145             $attempts = quiz_get_user_attempts($quiz->id, $USER->id, 'all');
146             list($someoptions, $alloptions) = quiz_get_combined_reviewoptions($quiz, $attempts, $context);
148             $grade = '';
149             $feedback = '';
150             if ($quiz->grade && array_key_exists($quiz->id, $scores)) {
151                 if ($alloptions->scores) {
152                     $a = new stdClass;
153                     $a->grade = quiz_format_grade($quiz, $scores[$quiz->id]);
154                     $a->maxgrade = quiz_format_grade($quiz, $quiz->grade);
155                     $grade = get_string('outofshort', 'quiz', $a);
156                 }
157                 if ($alloptions->overallfeedback) {
158                     $feedback = quiz_feedback_for_grade($scores[$quiz->id], $quiz, $context, $cm);
159                 }
160             }
161             $data[] = $grade;
162             if ($showfeedback) {
163                 $data[] = $feedback;
164             }
165         }
167         $table->data[] = $data;
168     } // End of loop over quiz instances.
170 // Display the table.
171     echo '<br />';
172     echo html_writer::table($table);
174 // Finish the page
175     echo $OUTPUT->footer();