rating MDL-21657 added aliasing and unaliasing of the fields returned by user_picture...
[moodle.git] / rating / index.php
1 <?php
3 // This file is part of Moodle - http://moodle.org/
4 //
5 // Moodle is free software: you can redistribute it and/or modify
6 // it under the terms of the GNU General Public License as published by
7 // the Free Software Foundation, either version 3 of the License, or
8 // (at your option) any later version.
9 //
10 // Moodle is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 // GNU General Public License for more details.
14 //
15 // You should have received a copy of the GNU General Public License
16 // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
18 /**
19  * A page to display a list of ratings for a given item (forum post etc)
20  *
21  * @package   moodlecore
22  * @copyright 2010 Andrew Davis
23  * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
24  */
26 require_once("../config.php");
27 require_once("lib.php");
29 $contextid   = required_param('contextid', PARAM_INT);
30 $itemid   = required_param('itemid', PARAM_INT);
31 $scaleid   = required_param('scaleid', PARAM_INT);
32 $sort = optional_param('sort', '', PARAM_ALPHA);
34 list($context, $course, $cm) = get_context_info_array($contextid);
35 require_login($course, false, $cm);
37 $url = new moodle_url('/rating/index.php', array('contextid'=>$contextid,'itemid'=>$itemid,'scaleid'=>$scaleid));
38 if ($sort !== 0) {
39     $url->param('sort', $sort);
40 }
41 $PAGE->set_url($url);
43 if ( !has_capability(RATING_VIEW,$context) ) {
44     print_error('noviewrate', 'rating');
45 }
46 if ( !has_capability(RATING_VIEW,$context) and $USER->id != $item->userid) {
47     print_error('noviewanyrate', 'rating');
48 }
50 switch ($sort) {
51     case 'firstname': $sqlsort = "u.firstname ASC"; break;
52     case 'rating':    $sqlsort = "r.rating ASC"; break;
53     default:          $sqlsort = "r.timemodified ASC";
54 }
56 $scalemenu = make_grades_menu($scaleid);
58 $strratings = get_string('ratings', 'rating');
59 $strrating  = get_string('rating', 'rating');
60 $strname    = get_string('name');
61 $strtime    = get_string('time');
63 //Is there something more meaningful we can put in the title?
64 //$PAGE->set_title("$strratings: ".format_string($post->subject));
65 $PAGE->set_title("$strratings: ".format_string($itemid));
66 echo $OUTPUT->header();
68 //if (!$ratings = forum_get_ratings($post->id, $sqlsort)) {
69 $ratings = rating::load_ratings_for_item($context, $itemid, $sort);
70 if (!$ratings) {
71     //print_error('noresult', 'forum', '', format_string($post->subject));
72     print_error('noresult');
73 } else {
74     echo "<table border=\"0\" cellpadding=\"3\" cellspacing=\"3\" class=\"generalbox\" style=\"width:100%\">";
75     echo "<tr>";
76     echo "<th class=\"header\" scope=\"col\">&nbsp;</th>";
77     echo "<th class=\"header\" scope=\"col\"><a href=\"report.php?id=$itemid&amp;sort=firstname\">$strname</a></th>";
78     echo "<th class=\"header\" scope=\"col\" style=\"width:100%\"><a href=\"report.php?id=$itemid&amp;sort=rating\">$strrating</a></th>";
79     echo "<th class=\"header\" scope=\"col\"><a href=\"report.php?id=$itemid&amp;sort=time\">$strtime</a></th>";
80     echo "</tr>";
81     $user = null;
82     foreach ($ratings as $rating) {
83         //undo the aliasing necessary for user_picture::fields
84         $user = clone($rating);//could get away with just overwriting rating->id and not cloning
85         //the rating object as we don't use rating->id again. That just seems like a bad idea.
86         $user->id = $user->uid;
87         
88         echo '<tr class="ratingitemheader">';
89         echo "<td>";
90         if($course && $course->id) {
91             echo $OUTPUT->user_picture($rating, array('courseid'=>$course->id));
92         } else {
93             echo $OUTPUT->user_picture($rating);
94         }
95         echo '</td><td>'.fullname($rating).'</td>';
96         echo '<td style="white-space:nowrap" align="center" class="rating">'.$scalemenu[$rating->rating]."</td>";
97         echo '<td style="white-space:nowrap" align="center" class="time">'.userdate($rating->timemodified)."</td>";
98         echo "</tr>\n";
99     }
100     echo "</table>";
101     echo "<br />";
104 echo $OUTPUT->close_window_button();
105 echo $OUTPUT->footer();