2009-07-07 02:26:36 +00:00
|
|
|
<?php
|
2007-07-23 14:33:02 +00:00
|
|
|
|
2009-07-07 02:26:36 +00:00
|
|
|
// 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/>.
|
2007-10-10 06:34:20 +00:00
|
|
|
|
2007-07-23 14:33:02 +00:00
|
|
|
include_once('../../../config.php');
|
|
|
|
require_once($CFG->libdir . '/gradelib.php');
|
2007-07-30 06:23:24 +00:00
|
|
|
require_once $CFG->dirroot.'/grade/lib.php';
|
2007-07-23 14:33:02 +00:00
|
|
|
|
2007-07-30 22:56:45 +00:00
|
|
|
$courseid = required_param('id', PARAM_INT); // course id
|
2007-07-23 14:33:02 +00:00
|
|
|
|
2008-06-03 16:10:57 +00:00
|
|
|
if (!$course = $DB->get_record('course', array('id' => $courseid))) {
|
2007-07-23 14:33:02 +00:00
|
|
|
print_error('nocourseid');
|
|
|
|
}
|
|
|
|
|
|
|
|
require_login($course->id);
|
|
|
|
$context = get_context_instance(CONTEXT_COURSE, $course->id);
|
|
|
|
|
2007-07-30 22:56:45 +00:00
|
|
|
require_capability('gradereport/outcomes:view', $context);
|
|
|
|
|
|
|
|
//first make sure we have proper final grades
|
|
|
|
grade_regrade_final_grades($courseid);
|
|
|
|
|
|
|
|
// Grab all outcomes used in course
|
2007-07-24 10:08:46 +00:00
|
|
|
$report_info = array();
|
2007-07-31 13:34:36 +00:00
|
|
|
$outcomes = grade_outcome::fetch_all_available($courseid);
|
2007-07-24 10:08:46 +00:00
|
|
|
|
|
|
|
// Get grade_items that use each outcome
|
|
|
|
foreach ($outcomes as $outcomeid => $outcome) {
|
2008-06-03 16:10:57 +00:00
|
|
|
$report_info[$outcomeid]['items'] = $DB->get_records_select('grade_items', "outcomeid = ? AND courseid = ?", array($outcomeid, $courseid));
|
2007-07-24 10:08:46 +00:00
|
|
|
$report_info[$outcomeid]['outcome'] = $outcome;
|
|
|
|
|
|
|
|
// Get average grades for each item
|
|
|
|
if (is_array($report_info[$outcomeid]['items'])) {
|
|
|
|
foreach ($report_info[$outcomeid]['items'] as $itemid => $item) {
|
2008-05-29 17:27:36 +00:00
|
|
|
$sql = "SELECT itemid, AVG(finalgrade) AS avg, COUNT(finalgrade) AS count
|
2008-06-02 16:06:33 +00:00
|
|
|
FROM {grade_grades}
|
2008-06-03 16:10:57 +00:00
|
|
|
WHERE itemid = ?
|
2007-07-24 10:08:46 +00:00
|
|
|
GROUP BY itemid";
|
2008-06-03 16:10:57 +00:00
|
|
|
$info = $DB->get_records_sql($sql, array($itemid));
|
2007-07-26 08:49:53 +00:00
|
|
|
|
|
|
|
if (!$info) {
|
|
|
|
unset($report_info[$outcomeid]['items'][$itemid]);
|
|
|
|
continue;
|
|
|
|
} else {
|
|
|
|
$info = reset($info);
|
|
|
|
$avg = round($info->avg, 2);
|
|
|
|
$count = $info->count;
|
|
|
|
}
|
|
|
|
|
|
|
|
$report_info[$outcomeid]['items'][$itemid]->avg = $avg;
|
|
|
|
$report_info[$outcomeid]['items'][$itemid]->count = $count;
|
2007-07-24 10:08:46 +00:00
|
|
|
}
|
|
|
|
}
|
2007-07-23 14:33:02 +00:00
|
|
|
}
|
|
|
|
|
2007-07-31 07:26:13 +00:00
|
|
|
$html = '<table class="generaltable boxaligncenter" width="90%" cellspacing="1" cellpadding="5" summary="Outcomes Report">' . "\n";
|
|
|
|
$html .= '<tr><th class="header c0" scope="col">' . get_string('outcomename', 'grades') . '</th>';
|
2008-02-28 15:52:23 +00:00
|
|
|
$html .= '<th class="header c1" scope="col">' . get_string('courseavg', 'grades') . '</th>';
|
2007-07-31 07:26:13 +00:00
|
|
|
$html .= '<th class="header c2" scope="col">' . get_string('sitewide', 'grades') . '</th>';
|
|
|
|
$html .= '<th class="header c3" scope="col">' . get_string('activities', 'grades') . '</th>';
|
|
|
|
$html .= '<th class="header c4" scope="col">' . get_string('average', 'grades') . '</th>';
|
|
|
|
$html .= '<th class="header c5" scope="col">' . get_string('numberofgrades', 'grades') . '</th></tr>' . "\n";
|
2007-07-24 10:08:46 +00:00
|
|
|
|
2007-07-31 07:26:13 +00:00
|
|
|
$row = 0;
|
2007-07-24 10:08:46 +00:00
|
|
|
foreach ($report_info as $outcomeid => $outcomedata) {
|
|
|
|
$rowspan = count($outcomedata['items']);
|
2008-02-28 12:41:26 +00:00
|
|
|
// If there are no items for this outcome, rowspan will equal 0, which is not good
|
|
|
|
if ($rowspan == 0) {
|
|
|
|
$rowspan = 1;
|
|
|
|
}
|
|
|
|
|
2007-07-31 07:26:13 +00:00
|
|
|
$shortname_html = '<tr class="r' . $row . '"><td class="cell c0" rowspan="' . $rowspan . '">' . $outcomedata['outcome']->shortname . "</td>\n";
|
2007-07-24 10:08:46 +00:00
|
|
|
|
|
|
|
$sitewide = get_string('no');
|
|
|
|
if (empty($outcomedata['outcome']->courseid)) {
|
|
|
|
$sitewide = get_string('yes');
|
|
|
|
}
|
|
|
|
|
2007-07-31 07:26:13 +00:00
|
|
|
$sitewide_html = '<td class="cell c2" rowspan="' . $rowspan . '">' . $sitewide . "</td>\n";
|
2007-07-24 14:26:05 +00:00
|
|
|
|
|
|
|
$outcomedata['outcome']->sum = 0;
|
|
|
|
$scale = new grade_scale(array('id' => $outcomedata['outcome']->scaleid), false);
|
2007-07-24 10:08:46 +00:00
|
|
|
|
|
|
|
$print_tr = false;
|
2007-07-24 14:26:05 +00:00
|
|
|
$items_html = '';
|
|
|
|
|
2008-02-28 12:41:26 +00:00
|
|
|
if (!empty($outcomedata['items'])) {
|
2007-07-24 10:08:46 +00:00
|
|
|
foreach ($outcomedata['items'] as $itemid => $item) {
|
|
|
|
if ($print_tr) {
|
2007-07-31 07:26:13 +00:00
|
|
|
$row++;
|
|
|
|
$items_html .= "<tr class=\"r$row\">\n";
|
2007-07-24 10:08:46 +00:00
|
|
|
}
|
|
|
|
|
2007-07-30 22:56:45 +00:00
|
|
|
$grade_item = new grade_item($item, false);
|
|
|
|
|
|
|
|
if ($item->itemtype == 'mod') {
|
|
|
|
$cm = get_coursemodule_from_instance($item->itemmodule, $item->iteminstance, $item->courseid);
|
2007-07-31 07:26:13 +00:00
|
|
|
$itemname = '<a href="'.$CFG->wwwroot.'/mod/'.$item->itemmodule.'/view.php?id='.$cm->id.'">'.$grade_item->get_name().'</a>';
|
2007-07-30 22:56:45 +00:00
|
|
|
} else {
|
|
|
|
$itemname = $grade_item->get_name();
|
|
|
|
}
|
2007-07-24 10:08:46 +00:00
|
|
|
|
2007-07-24 14:26:05 +00:00
|
|
|
$outcomedata['outcome']->sum += $item->avg;
|
|
|
|
$gradehtml = $scale->get_nearest_item($item->avg);
|
2007-07-24 10:08:46 +00:00
|
|
|
|
2007-07-31 07:26:13 +00:00
|
|
|
$items_html .= "<td class=\"cell c3\">$itemname</td>"
|
|
|
|
. "<td class=\"cell c4\">$gradehtml ($item->avg)</td>"
|
|
|
|
. "<td class=\"cell c5\">$item->count</td></tr>\n";
|
2007-07-24 10:08:46 +00:00
|
|
|
$print_tr = true;
|
|
|
|
}
|
|
|
|
} else {
|
2007-07-31 07:26:13 +00:00
|
|
|
$items_html .= "<td class=\"cell c3\"> - </td><td class=\"cell c4\"> - </td><td class=\"cell c5\"> 0 </td></tr>\n";
|
2007-07-24 14:26:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Calculate outcome average
|
|
|
|
if (is_array($outcomedata['items'])) {
|
2007-08-10 14:58:21 +00:00
|
|
|
$count = count($outcomedata['items']);
|
|
|
|
if ($count > 0) {
|
|
|
|
$avg = $outcomedata['outcome']->sum / $count;
|
|
|
|
} else {
|
|
|
|
$avg = $outcomedata['outcome']->sum;
|
|
|
|
}
|
2007-07-24 14:26:05 +00:00
|
|
|
$avg_html = $scale->get_nearest_item($avg) . " (" . round($avg, 2) . ")\n";
|
|
|
|
} else {
|
|
|
|
$avg_html = ' - ';
|
2007-07-24 10:08:46 +00:00
|
|
|
}
|
2007-07-24 14:26:05 +00:00
|
|
|
|
2007-07-31 07:26:13 +00:00
|
|
|
$outcomeavg_html = '<td class="cell c1" rowspan="' . $rowspan . '">' . $avg_html . "</td>\n";
|
2007-07-24 14:26:05 +00:00
|
|
|
|
|
|
|
$html .= $shortname_html . $outcomeavg_html . $sitewide_html . $items_html;
|
2007-07-31 07:26:13 +00:00
|
|
|
$row++;
|
2007-07-24 10:08:46 +00:00
|
|
|
}
|
2007-07-23 14:33:02 +00:00
|
|
|
|
|
|
|
|
2007-07-24 14:26:05 +00:00
|
|
|
|
2007-07-24 10:08:46 +00:00
|
|
|
$html .= '</table>';
|
2009-02-09 10:49:41 +00:00
|
|
|
|
|
|
|
print_grade_page_head($courseid, 'report', 'outcomes');
|
|
|
|
|
2007-07-31 07:26:13 +00:00
|
|
|
|
2007-07-24 10:08:46 +00:00
|
|
|
echo $html;
|
2009-08-06 14:12:17 +00:00
|
|
|
echo $OUTPUT->footer();
|
2007-07-23 14:33:02 +00:00
|
|
|
|
|
|
|
?>
|