Merge branch 'w18_MDL-26028_m23_xsendfile' of git://github.com/skodak/moodle
[moodle.git] / mod / lti / grade.php
blobe8c19a1d2a5bb39562641f8d0deca8a40f8f1018
1 <?php
2 // This file is part of Moodle - http://moodle.org/
3 //
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
17 // This file is part of BasicLTI4Moodle
19 // BasicLTI4Moodle is an IMS BasicLTI (Basic Learning Tools for Interoperability)
20 // consumer for Moodle 1.9 and Moodle 2.0. BasicLTI is a IMS Standard that allows web
21 // based learning tools to be easily integrated in LMS as native ones. The IMS BasicLTI
22 // specification is part of the IMS standard Common Cartridge 1.1 Sakai and other main LMS
23 // are already supporting or going to support BasicLTI. This project Implements the consumer
24 // for Moodle. Moodle is a Free Open source Learning Management System by Martin Dougiamas.
25 // BasicLTI4Moodle is a project iniciated and leaded by Ludo(Marc Alier) and Jordi Piguillem
26 // at the GESSI research group at UPC.
27 // SimpleLTI consumer for Moodle is an implementation of the early specification of LTI
28 // by Charles Severance (Dr Chuck) htp://dr-chuck.com , developed by Jordi Piguillem in a
29 // Google Summer of Code 2008 project co-mentored by Charles Severance and Marc Alier.
31 // BasicLTI4Moodle is copyright 2009 by Marc Alier Forment, Jordi Piguillem and Nikolas Galanis
32 // of the Universitat Politecnica de Catalunya http://www.upc.edu
33 // Contact info: Marc Alier Forment granludo @ gmail.com or marc.alier @ upc.edu
35 /**
36 * This file contains submissions-specific code for the lti module
38 * @package mod
39 * @subpackage lti
40 * @copyright 2009 Marc Alier, Jordi Piguillem, Nikolas Galanis
41 * marc.alier@upc.edu
42 * @copyright 2009 Universitat Politecnica de Catalunya http://www.upc.edu
43 * @author Marc Alier
44 * @author Jordi Piguillem
45 * @author Nikolas Galanis
46 * @author Chris Scribner
47 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
50 require_once("../../config.php");
51 require_once($CFG->dirroot.'/mod/lti/lib.php');
52 require_once($CFG->libdir.'/plagiarismlib.php');
54 $id = optional_param('id', 0, PARAM_INT); // Course module ID
55 $l = optional_param('l', 0, PARAM_INT); // lti instance ID
56 $mode = optional_param('mode', 'all', PARAM_ALPHA); // What mode are we in?
57 $download = optional_param('download' , 'none', PARAM_ALPHA); //ZIP download asked for?
59 if ($l) { // Two ways to specify the module
60 $lti = $DB->get_record('lti', array('id' => $l), '*', MUST_EXIST);
61 $cm = get_coursemodule_from_instance('lti', $lti->id, $lti->course, false, MUST_EXIST);
63 } else {
64 $cm = get_coursemodule_from_id('lti', $id, 0, false, MUST_EXIST);
65 $lti = $DB->get_record('lti', array('id' => $cm->instance), '*', MUST_EXIST);
68 $course = $DB->get_record('course', array('id' => $cm->course), '*', MUST_EXIST);
70 require_login($course, false, $cm);
71 $context = get_context_instance(CONTEXT_MODULE, $cm->id);
72 require_capability('mod/lti:grade', $context);
74 $url = new moodle_url('/mod/lti/grade.php', array('id' => $cm->id));
75 if ($mode !== 'all') {
76 $url->param('mode', $mode);
78 $PAGE->set_url($url);
80 $module = array(
81 'name' => 'mod_lti_submissions',
82 'fullpath' => '/mod/lti/submissions.js',
83 'requires' => array('base'),
84 'strings' => array(),
87 $PAGE->requires->js_init_call('M.mod_lti.submissions.init', array(), true, $module);
89 $PAGE->requires->yui2_lib('datatable');
91 $submissionquery = '
92 SELECT s.id, u.firstname, u.lastname, u.id AS userid, s.datesubmitted, s.gradepercent
93 FROM {lti_submission} s
94 INNER JOIN {user} u ON s.userid = u.id
95 WHERE s.ltiid = :ltiid
96 ORDER BY s.datesubmitted DESC
99 $submissions = $DB->get_records_sql($submissionquery, array('ltiid' => $lti->id));
101 $html = '
102 <noscript>
103 <!-- If javascript is disabled, we need to show the table using CSS.
104 The table starts out hidden to avoid flickering as it loads -->
105 <style type="text/css">
106 #lti_submissions_table_container { display: block !important; }
107 </style>
108 </noscript>
110 <div id="lti_submissions_table_container" style="display:none">
111 <table id="lti_submissions_table">
112 <thead>
113 <tr>
114 <th>User</th>
115 <th>Date</th>
116 <th>Grade</th>
117 </tr>
118 </thead>
119 <tbody>
120 <!--table body-->
121 </tbody>
122 </table>
123 </div>
126 $rowtemplate = '
127 <tr>
128 <td>
129 <!--firstname--> <!--lastname-->
130 </td>
131 <td>
132 <!--datesubmitted-->
133 </td>
134 <td>
135 <!--gradepercent-->
136 </td>
137 </tr>
140 $rows = '';
142 foreach ($submissions as $submission) {
143 $row = $rowtemplate;
145 foreach ($submission as $key => $value) {
146 if ($key === 'datesubmitted') {
147 $value = userdate($value);
150 $row = str_replace('<!--' . $key . '-->', $value, $row);
153 $rows .= $row;
156 $table = str_replace('<!--table body-->', $rows, $html);
158 $title = 'Submissions for ' . $lti->name;
160 $PAGE->set_title(format_string($title , true));
161 $PAGE->set_heading($course->fullname);
163 echo $OUTPUT->header();
164 echo $OUTPUT->heading($title );
166 echo $table;
168 echo $OUTPUT->footer();