2009-07-07 02:26:36 +00:00
< ? 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/>.
2007-10-10 06:34:20 +00:00
2007-07-16 04:09:00 +00:00
/**
2012-01-06 11:52:46 +07:00
* Definition of the grade_user_report class is defined
*
* @ package gradereport_user
* @ copyright 2007 Nicolas Connault
* @ license http :// www . gnu . org / copyleft / gpl . html GNU GPL v3 or later
2007-07-16 04:09:00 +00:00
*/
require_once ( $CFG -> dirroot . '/grade/report/lib.php' );
require_once ( $CFG -> libdir . '/tablelib.php' );
2010-01-08 07:48:37 +00:00
//showhiddenitems values
define ( " GRADE_REPORT_USER_HIDE_HIDDEN " , 0 );
define ( " GRADE_REPORT_USER_HIDE_UNTIL " , 1 );
define ( " GRADE_REPORT_USER_SHOW_HIDDEN " , 2 );
2007-07-16 04:09:00 +00:00
/**
* Class providing an API for the user report building and displaying .
* @ uses grade_report
2012-01-06 11:52:46 +07:00
* @ package gradereport_user
2007-07-16 04:09:00 +00:00
*/
class grade_report_user extends grade_report {
/**
* The user .
* @ var object $user
*/
2008-06-03 16:10:57 +00:00
public $user ;
2007-07-16 04:09:00 +00:00
/**
* A flexitable to hold the data .
* @ var object $table
*/
2008-06-03 16:10:57 +00:00
public $table ;
2007-07-16 04:09:00 +00:00
2011-01-18 16:24:41 +08:00
/**
* An array of table headers
* @ var array
*/
public $tableheaders = array ();
/**
* An array of table columns
* @ var array
*/
public $tablecolumns = array ();
/**
* An array containing rows of data for the table .
* @ var type
*/
public $tabledata = array ();
/**
* The grade tree structure
* @ var grade_tree
*/
public $gtree ;
2009-04-16 07:16:44 +00:00
2007-10-08 23:09:10 +00:00
/**
* Flat structure similar to grade tree
*/
2008-06-03 16:10:57 +00:00
public $gseq ;
2007-10-08 23:09:10 +00:00
2007-10-27 15:33:43 +00:00
/**
* show student ranks
*/
2008-06-03 16:10:57 +00:00
public $showrank ;
2007-10-27 15:33:43 +00:00
2008-10-08 11:06:05 +00:00
/**
* show grade percentages
*/
public $showpercentage ;
2009-02-25 07:56:11 +00:00
/**
* Show range
*/
2011-01-18 16:24:41 +08:00
public $showrange = true ;
2009-02-25 07:56:11 +00:00
2011-01-18 16:24:41 +08:00
/**
* Show grades in the report , default true
* @ var bool
*/
public $showgrade = true ;
2009-02-25 07:56:11 +00:00
2011-01-18 16:24:41 +08:00
/**
* Decimal points to use for values in the report , default 2
* @ var int
*/
public $decimals = 2 ;
2009-02-25 07:56:11 +00:00
2011-01-18 16:24:41 +08:00
/**
* The number of decimal places to round range to , default 0
* @ var int
*/
public $rangedecimals = 0 ;
2009-02-25 07:56:11 +00:00
2011-01-18 16:24:41 +08:00
/**
* Show grade feedback in the report , default true
* @ var bool
*/
public $showfeedback = true ;
/**
2014-10-10 14:55:37 +08:00
* Show grade weighting in the report , default true .
2011-01-18 16:24:41 +08:00
* @ var bool
*/
2014-10-10 14:55:37 +08:00
public $showweight = true ;
2011-01-18 16:24:41 +08:00
/**
* Show letter grades in the report , default false
* @ var bool
*/
public $showlettergrade = false ;
2014-08-13 14:23:59 +08:00
/**
* Show the calculated contribution to the course total column .
* @ var bool
*/
2014-10-10 14:55:37 +08:00
public $showcontributiontocoursetotal = true ;
2014-08-13 14:23:59 +08:00
2011-01-18 16:24:41 +08:00
/**
* Show average grades in the report , default false .
* @ var false
*/
public $showaverage = false ;
public $maxdepth ;
public $evenodd ;
public $canviewhidden ;
public $switch ;
2009-02-25 07:56:11 +00:00
2007-10-27 15:33:43 +00:00
/**
* Show hidden items even when user does not have required cap
*/
2008-06-03 16:10:57 +00:00
public $showhiddenitems ;
2011-01-18 16:24:41 +08:00
public $showtotalsifcontainhidden ;
public $baseurl ;
public $pbarurl ;
2007-10-27 15:33:43 +00:00
2014-08-11 11:53:06 +08:00
/**
* The modinfo object to be used .
*
* @ var course_modinfo
*/
protected $modinfo = null ;
/**
* View as user .
*
* When this is set to true , the visibility checks , and capability checks will be
* applied to the user whose grades are being displayed . This is very useful when
* a mentor / parent is viewing the report of their mentee because they need to have
* access to the same information , but not more , not less .
*
* @ var boolean
*/
protected $viewasuser = false ;
2014-09-24 16:21:30 +08:00
/**
* An array that collects the aggregationhints for every
* grade_item . The hints contain grade , grademin , grademax
* status , weight and parent .
*
* @ var array
*/
protected $aggregationhints = array ();
2007-07-16 04:09:00 +00:00
/**
* Constructor . Sets local copies of user preferences and initialises grade_tree .
* @ param int $courseid
2007-07-17 06:09:03 +00:00
* @ param object $gpr grade plugin return tracking object
2007-07-16 04:09:00 +00:00
* @ param string $context
* @ param int $userid The id of the user
2014-08-11 11:53:06 +08:00
* @ param bool $viewasuser Set this to true when the current user is a mentor / parent of the targetted user .
2007-07-16 04:09:00 +00:00
*/
2014-08-11 11:53:06 +08:00
public function __construct ( $courseid , $gpr , $context , $userid , $viewasuser = null ) {
2011-01-18 16:24:41 +08:00
global $DB , $CFG ;
2008-06-03 16:10:57 +00:00
parent :: __construct ( $courseid , $gpr , $context );
2007-07-16 04:09:00 +00:00
2007-10-30 21:25:50 +00:00
$this -> showrank = grade_get_setting ( $this -> courseid , 'report_user_showrank' , $CFG -> grade_report_user_showrank );
2008-10-08 11:06:05 +00:00
$this -> showpercentage = grade_get_setting ( $this -> courseid , 'report_user_showpercentage' , $CFG -> grade_report_user_showpercentage );
2007-10-30 21:25:50 +00:00
$this -> showhiddenitems = grade_get_setting ( $this -> courseid , 'report_user_showhiddenitems' , $CFG -> grade_report_user_showhiddenitems );
2013-03-05 12:00:59 +08:00
$this -> showtotalsifcontainhidden = array ( $this -> courseid => grade_get_setting ( $this -> courseid , 'report_user_showtotalsifcontainhidden' , $CFG -> grade_report_user_showtotalsifcontainhidden ));
2009-04-16 07:16:44 +00:00
2011-01-18 16:24:41 +08:00
$this -> showgrade = grade_get_setting ( $this -> courseid , 'report_user_showgrade' , ! empty ( $CFG -> grade_report_user_showgrade ));
$this -> showrange = grade_get_setting ( $this -> courseid , 'report_user_showrange' , ! empty ( $CFG -> grade_report_user_showrange ));
$this -> showfeedback = grade_get_setting ( $this -> courseid , 'report_user_showfeedback' , ! empty ( $CFG -> grade_report_user_showfeedback ));
2014-10-10 14:55:37 +08:00
$this -> showweight = grade_get_setting ( $this -> courseid , 'report_user_showweight' ,
2014-10-15 13:39:36 +08:00
! empty ( $CFG -> grade_report_user_showweight ));
2014-10-10 14:55:37 +08:00
$this -> showcontributiontocoursetotal = grade_get_setting ( $this -> courseid , 'report_user_showcontributiontocoursetotal' ,
2014-10-15 13:39:36 +08:00
! empty ( $CFG -> grade_report_user_showcontributiontocoursetotal ));
2014-10-10 14:55:37 +08:00
2011-01-18 16:24:41 +08:00
$this -> showlettergrade = grade_get_setting ( $this -> courseid , 'report_user_showlettergrade' , ! empty ( $CFG -> grade_report_user_showlettergrade ));
$this -> showaverage = grade_get_setting ( $this -> courseid , 'report_user_showaverage' , ! empty ( $CFG -> grade_report_user_showaverage ));
2014-08-11 11:53:06 +08:00
$this -> viewasuser = $viewasuser ;
2011-01-18 16:24:41 +08:00
// The default grade decimals is 2
$defaultdecimals = 2 ;
if ( property_exists ( $CFG , 'grade_decimalpoints' )) {
$defaultdecimals = $CFG -> grade_decimalpoints ;
}
$this -> decimals = grade_get_setting ( $this -> courseid , 'decimalpoints' , $defaultdecimals );
// The default range decimals is 0
$defaultrangedecimals = 0 ;
if ( property_exists ( $CFG , 'grade_report_user_rangedecimals' )) {
$defaultrangedecimals = $CFG -> grade_report_user_rangedecimals ;
}
$this -> rangedecimals = grade_get_setting ( $this -> courseid , 'report_user_rangedecimals' , $defaultrangedecimals );
2009-02-25 07:56:11 +00:00
$this -> switch = grade_get_setting ( $this -> courseid , 'aggregationposition' , $CFG -> grade_aggregationposition );
// Grab the grade_tree for this course
2010-09-17 19:05:23 +00:00
$this -> gtree = new grade_tree ( $this -> courseid , false , $this -> switch , null , ! $CFG -> enableoutcomes );
2007-10-27 15:33:43 +00:00
2014-08-11 11:53:06 +08:00
// Get the user (for full name).
2008-06-03 16:10:57 +00:00
$this -> user = $DB -> get_record ( 'user' , array ( 'id' => $userid ));
2007-07-16 04:09:00 +00:00
2014-08-11 11:53:06 +08:00
// What user are we viewing this as?
$coursecontext = context_course :: instance ( $this -> courseid );
if ( $viewasuser ) {
$this -> modinfo = new course_modinfo ( $this -> course , $this -> user -> id );
$this -> canviewhidden = has_capability ( 'moodle/grade:viewhidden' , $coursecontext , $this -> user -> id );
} else {
$this -> modinfo = $this -> gtree -> modinfo ;
$this -> canviewhidden = has_capability ( 'moodle/grade:viewhidden' , $coursecontext );
}
2014-10-16 22:27:52 -05:00
// Determine the number of rows and indentation.
$this -> maxdepth = 1 ;
$this -> inject_rowspans ( $this -> gtree -> top_element );
$this -> maxdepth ++ ; // Need to account for the lead column that spans all children.
for ( $i = 1 ; $i <= $this -> maxdepth ; $i ++ ) {
$this -> evenodd [ $i ] = 0 ;
}
$this -> tabledata = array ();
2007-07-16 04:09:00 +00:00
// base url for sorting by first/last name
$this -> baseurl = $CFG -> wwwroot . '/grade/report?id=' . $courseid . '&userid=' . $userid ;
2007-07-20 09:34:35 +00:00
$this -> pbarurl = $this -> baseurl ;
2007-07-16 04:09:00 +00:00
2007-10-28 12:51:16 +00:00
// no groups on this report - rank is from all course users
2007-07-20 09:34:35 +00:00
$this -> setup_table ();
2011-01-18 16:24:41 +08:00
//optionally calculate grade item averages
$this -> calculate_averages ();
2007-07-16 04:09:00 +00:00
}
2012-07-30 12:10:23 +08:00
/**
* Recurses through a tree of elements setting the rowspan property on each element
*
* @ param array $element Either the top element or , during recursion , the current element
* @ return int The number of elements processed
*/
2009-02-25 07:56:11 +00:00
function inject_rowspans ( & $element ) {
2012-07-30 12:10:23 +08:00
2009-02-25 07:56:11 +00:00
if ( $element [ 'depth' ] > $this -> maxdepth ) {
$this -> maxdepth = $element [ 'depth' ];
}
if ( empty ( $element [ 'children' ])) {
return 1 ;
}
$count = 1 ;
2012-07-30 12:10:23 +08:00
2009-02-25 07:56:11 +00:00
foreach ( $element [ 'children' ] as $key => $child ) {
2014-10-16 22:27:52 -05:00
// If category is hidden then do not include it in the rowspan.
if ( $child [ 'type' ] == 'category' && $child [ 'object' ] -> is_hidden () && ! $this -> canviewhidden
&& ( $this -> showhiddenitems == GRADE_REPORT_USER_HIDE_HIDDEN
|| ( $this -> showhiddenitems == GRADE_REPORT_USER_HIDE_UNTIL && ! $child [ 'object' ] -> is_hiddenuntil ()))) {
// Just calculate the rowspans for children of this category, don't add them to the count.
$this -> inject_rowspans ( $element [ 'children' ][ $key ]);
} else {
$count += $this -> inject_rowspans ( $element [ 'children' ][ $key ]);
}
2009-02-25 07:56:11 +00:00
}
2012-07-30 12:10:23 +08:00
2009-02-25 07:56:11 +00:00
$element [ 'rowspan' ] = $count ;
return $count ;
}
2007-07-16 04:09:00 +00:00
/**
* Prepares the headers and attributes of the flexitable .
*/
2008-06-03 16:10:57 +00:00
public function setup_table () {
2007-07-16 04:09:00 +00:00
/*
2011-01-18 16:24:41 +08:00
* Table has 1 - 8 columns
*| All columns except for itemname / description are optional
2007-10-28 12:51:16 +00:00
*/
2007-07-16 04:09:00 +00:00
// setting up table headers
2011-01-18 16:24:41 +08:00
$this -> tablecolumns = array ( 'itemname' );
$this -> tableheaders = array ( $this -> get_lang_string ( 'gradeitem' , 'grades' ));
if ( $this -> showweight ) {
$this -> tablecolumns [] = 'weight' ;
$this -> tableheaders [] = $this -> get_lang_string ( 'weightuc' , 'grades' );
}
if ( $this -> showgrade ) {
$this -> tablecolumns [] = 'grade' ;
$this -> tableheaders [] = $this -> get_lang_string ( 'grade' , 'grades' );
}
2008-10-08 11:06:05 +00:00
2009-02-25 07:56:11 +00:00
if ( $this -> showrange ) {
$this -> tablecolumns [] = 'range' ;
$this -> tableheaders [] = $this -> get_lang_string ( 'range' , 'grades' );
}
2008-10-08 11:06:05 +00:00
if ( $this -> showpercentage ) {
2009-02-25 07:56:11 +00:00
$this -> tablecolumns [] = 'percentage' ;
$this -> tableheaders [] = $this -> get_lang_string ( 'percentage' , 'grades' );
2008-10-08 11:06:05 +00:00
}
2011-01-18 16:24:41 +08:00
if ( $this -> showlettergrade ) {
$this -> tablecolumns [] = 'lettergrade' ;
$this -> tableheaders [] = $this -> get_lang_string ( 'lettergrade' , 'grades' );
}
2007-10-27 15:33:43 +00:00
if ( $this -> showrank ) {
2009-02-25 07:56:11 +00:00
$this -> tablecolumns [] = 'rank' ;
$this -> tableheaders [] = $this -> get_lang_string ( 'rank' , 'grades' );
2007-10-21 12:56:19 +00:00
}
2007-07-16 04:09:00 +00:00
2011-01-18 16:24:41 +08:00
if ( $this -> showaverage ) {
$this -> tablecolumns [] = 'average' ;
$this -> tableheaders [] = $this -> get_lang_string ( 'average' , 'grades' );
}
2007-07-16 04:09:00 +00:00
2011-01-18 16:24:41 +08:00
if ( $this -> showfeedback ) {
$this -> tablecolumns [] = 'feedback' ;
$this -> tableheaders [] = $this -> get_lang_string ( 'feedback' , 'grades' );
}
2014-08-13 14:23:59 +08:00
if ( $this -> showcontributiontocoursetotal ) {
$this -> tablecolumns [] = 'contributiontocoursetotal' ;
$this -> tableheaders [] = $this -> get_lang_string ( 'contributiontocoursetotal' , 'grades' );
}
2009-02-25 07:56:11 +00:00
}
2007-07-16 04:09:00 +00:00
2009-02-25 07:56:11 +00:00
function fill_table () {
//print "<pre>";
//print_r($this->gtree->top_element);
$this -> fill_table_recursive ( $this -> gtree -> top_element );
//print_r($this->tabledata);
//print "</pre>";
return true ;
2007-07-16 04:09:00 +00:00
}
2014-09-24 13:22:41 +08:00
/**
* Fill the table with data .
*
* @ param $element - An array containing the table data for the current row .
*/
2014-09-24 16:21:30 +08:00
private function fill_table_recursive ( & $element ) {
2011-01-18 16:24:41 +08:00
global $DB , $CFG ;
2007-07-16 04:09:00 +00:00
2009-02-25 07:56:11 +00:00
$type = $element [ 'type' ];
$depth = $element [ 'depth' ];
$grade_object = $element [ 'object' ];
$eid = $grade_object -> id ;
2011-11-08 14:09:50 +08:00
$element [ 'userid' ] = $this -> user -> id ;
2014-10-15 09:33:52 +08:00
$fullname = $this -> gtree -> get_element_header ( $element , true , true , true , true , true );
2009-02-25 07:56:11 +00:00
$data = array ();
$hidden = '' ;
$excluded = '' ;
2014-10-02 18:35:10 +08:00
$itemlevel = ( $type == 'categoryitem' || $type == 'category' || $type == 'courseitem' ) ? $depth : ( $depth + 1 );
$class = 'level' . $itemlevel . ' level' . ( $itemlevel % 2 ? 'odd' : 'even' );
2012-03-04 12:21:03 +07:00
$classfeedback = '' ;
2007-07-16 04:09:00 +00:00
2010-01-08 07:48:37 +00:00
// If this is a hidden grade category, hide it completely from the user
2009-04-30 08:40:22 +00:00
if ( $type == 'category' && $grade_object -> is_hidden () && ! $this -> canviewhidden && (
2010-01-08 07:48:37 +00:00
$this -> showhiddenitems == GRADE_REPORT_USER_HIDE_HIDDEN ||
( $this -> showhiddenitems == GRADE_REPORT_USER_HIDE_UNTIL && ! $grade_object -> is_hiddenuntil ()))) {
2009-04-16 07:16:44 +00:00
return false ;
}
2007-10-17 09:45:14 +00:00
2009-02-25 07:56:11 +00:00
if ( $type == 'category' ) {
$this -> evenodd [ $depth ] = (( $this -> evenodd [ $depth ] + 1 ) % 2 );
2007-10-17 20:38:52 +00:00
}
2009-02-25 07:56:11 +00:00
$alter = ( $this -> evenodd [ $depth ] == 0 ) ? 'even' : 'odd' ;
2007-10-17 09:45:14 +00:00
2009-02-25 07:56:11 +00:00
/// Process those items that have scores associated
if ( $type == 'item' or $type == 'categoryitem' or $type == 'courseitem' ) {
2013-08-02 13:54:58 +08:00
$header_row = " row_ { $eid } _ { $this -> user -> id } " ;
$header_cat = " cat_ { $grade_object -> categoryid } _ { $this -> user -> id } " ;
2009-02-25 07:56:11 +00:00
if ( ! $grade_grade = grade_grade :: fetch ( array ( 'itemid' => $grade_object -> id , 'userid' => $this -> user -> id ))) {
$grade_grade = new grade_grade ();
$grade_grade -> userid = $this -> user -> id ;
$grade_grade -> itemid = $grade_object -> id ;
2007-10-19 08:51:52 +00:00
}
2007-10-17 09:45:14 +00:00
2009-02-25 07:56:11 +00:00
$grade_grade -> load_grade_item ();
2007-07-16 04:09:00 +00:00
2009-02-25 07:56:11 +00:00
/// Hidden Items
if ( $grade_grade -> grade_item -> is_hidden ()) {
2014-08-19 12:53:22 +08:00
$hidden = ' dimmed_text' ;
2007-11-01 08:25:05 +00:00
}
2012-09-18 13:41:11 +08:00
$hide = false ;
2010-01-08 07:48:37 +00:00
// If this is a hidden grade item, hide it completely from the user.
2009-04-16 07:16:44 +00:00
if ( $grade_grade -> is_hidden () && ! $this -> canviewhidden && (
2010-01-08 07:48:37 +00:00
$this -> showhiddenitems == GRADE_REPORT_USER_HIDE_HIDDEN ||
( $this -> showhiddenitems == GRADE_REPORT_USER_HIDE_UNTIL && ! $grade_grade -> is_hiddenuntil ()))) {
2012-09-18 13:41:11 +08:00
$hide = true ;
} else if ( ! empty ( $grade_object -> itemmodule ) && ! empty ( $grade_object -> iteminstance )) {
2014-03-26 12:01:52 +00:00
// The grade object can be marked visible but still be hidden if
// the student cannot see the activity due to conditional access
// and it's set to be hidden entirely.
2014-08-11 11:53:06 +08:00
$instances = $this -> modinfo -> get_instances_of ( $grade_object -> itemmodule );
2012-09-18 13:41:11 +08:00
if ( ! empty ( $instances [ $grade_object -> iteminstance ])) {
$cm = $instances [ $grade_object -> iteminstance ];
2012-10-09 11:22:54 +08:00
if ( ! $cm -> uservisible ) {
2014-03-26 12:01:52 +00:00
// If there is 'availableinfo' text then it is only greyed
// out and not entirely hidden.
if ( ! $cm -> availableinfo ) {
2012-10-09 11:22:54 +08:00
$hide = true ;
}
2012-04-08 11:10:44 +07:00
}
}
2012-09-18 13:41:11 +08:00
}
2014-10-23 11:22:10 +08:00
// Actual Grade - We need to calculate this whether the row is hidden or not.
$gradeval = $grade_grade -> finalgrade ;
$hint = $grade_grade -> get_aggregation_hint ();
if ( ! $this -> canviewhidden ) {
/// Virtual Grade (may be calculated excluding hidden items etc).
$adjustedgrade = $this -> blank_hidden_total_and_adjust_bounds ( $this -> courseid ,
$grade_grade -> grade_item ,
$gradeval );
$gradeval = $adjustedgrade [ 'grade' ];
// We temporarily adjust the view of this grade item - because the min and
// max are affected by the hidden values in the aggregation.
$grade_grade -> grade_item -> grademax = $adjustedgrade [ 'grademax' ];
$grade_grade -> grade_item -> grademin = $adjustedgrade [ 'grademin' ];
$hint [ 'status' ] = $adjustedgrade [ 'aggregationstatus' ];
$hint [ 'weight' ] = $adjustedgrade [ 'aggregationweight' ];
} else {
// The max and min for an aggregation may be different to the grade_item.
if ( ! is_null ( $gradeval )) {
$grade_grade -> grade_item -> grademax = $grade_grade -> rawgrademax ;
$grade_grade -> grade_item -> grademin = $grade_grade -> rawgrademin ;
}
}
2012-09-18 13:41:11 +08:00
if ( ! $hide ) {
2010-02-12 03:39:40 +00:00
/// Excluded Item
2014-08-07 16:33:09 +08:00
/**
2010-02-12 03:39:40 +00:00
if ( $grade_grade -> is_excluded ()) {
$fullname .= ' [' . get_string ( 'excluded' , 'grades' ) . ']' ;
$excluded = ' excluded' ;
}
2014-08-07 16:33:09 +08:00
**/
2009-04-16 07:16:44 +00:00
2010-02-12 03:39:40 +00:00
/// Other class information
2014-10-02 18:35:10 +08:00
$class .= $hidden . $excluded ;
2010-02-12 03:39:40 +00:00
if ( $this -> switch ) { // alter style based on whether aggregation is first or last
$class .= ( $type == 'categoryitem' or $type == 'courseitem' ) ? " " . $alter . " d $depth baggt b2b " : " item b1b " ;
} else {
$class .= ( $type == 'categoryitem' or $type == 'courseitem' ) ? " " . $alter . " d $depth baggb " : " item b1b " ;
}
2013-08-05 11:20:32 +08:00
if ( $type == 'categoryitem' or $type == 'courseitem' ) {
$header_cat = " cat_ { $grade_object -> iteminstance } _ { $this -> user -> id } " ;
}
2007-07-16 04:09:00 +00:00
2010-02-12 03:39:40 +00:00
/// Name
$data [ 'itemname' ][ 'content' ] = $fullname ;
$data [ 'itemname' ][ 'class' ] = $class ;
$data [ 'itemname' ][ 'colspan' ] = ( $this -> maxdepth - $depth );
2013-08-02 13:54:58 +08:00
$data [ 'itemname' ][ 'celltype' ] = 'th' ;
$data [ 'itemname' ][ 'id' ] = $header_row ;
2007-10-08 23:09:10 +00:00
2012-03-04 12:21:03 +07:00
if ( $this -> showfeedback ) {
// Copy $class before appending itemcenter as feedback should not be centered
$classfeedback = $class ;
}
2011-01-18 16:24:41 +08:00
$class .= " itemcenter " ;
if ( $this -> showweight ) {
$data [ 'weight' ][ 'class' ] = $class ;
$data [ 'weight' ][ 'content' ] = '-' ;
2013-08-02 13:54:58 +08:00
$data [ 'weight' ][ 'headers' ] = " $header_cat $header_row weight " ;
2011-01-18 16:24:41 +08:00
// has a weight assigned, might be extra credit
2014-08-07 16:33:09 +08:00
2014-09-19 16:34:01 +08:00
// This obliterates the weight because it provides a more informative description.
if ( is_numeric ( $hint [ 'weight' ])) {
$data [ 'weight' ][ 'content' ] = format_float ( $hint [ 'weight' ] * 100.0 , 2 ) . ' %' ;
}
if ( $hint [ 'status' ] != 'used' && $hint [ 'status' ] != 'unknown' ) {
2014-09-24 16:21:30 +08:00
$data [ 'weight' ][ 'content' ] .= '<br>' . get_string ( 'aggregationhint' . $hint [ 'status' ], 'grades' );
2011-01-18 16:24:41 +08:00
}
2008-10-08 11:06:05 +00:00
}
2007-10-17 09:45:14 +00:00
2011-01-18 16:24:41 +08:00
if ( $this -> showgrade ) {
if ( $grade_grade -> grade_item -> needsupdate ) {
$data [ 'grade' ][ 'class' ] = $class . ' gradingerror' ;
$data [ 'grade' ][ 'content' ] = get_string ( 'error' );
} else if ( ! empty ( $CFG -> grade_hiddenasdate ) and $grade_grade -> get_datesubmitted () and ! $this -> canviewhidden and $grade_grade -> is_hidden ()
and ! $grade_grade -> grade_item -> is_category_item () and ! $grade_grade -> grade_item -> is_course_item ()) {
// the problem here is that we do not have the time when grade value was modified, 'timemodified' is general modification date for grade_grades records
$class .= ' datesubmitted' ;
$data [ 'grade' ][ 'class' ] = $class ;
$data [ 'grade' ][ 'content' ] = get_string ( 'submittedon' , 'grades' , userdate ( $grade_grade -> get_datesubmitted (), get_string ( 'strftimedatetimeshort' )));
2014-08-29 09:48:44 +08:00
} else if ( $grade_grade -> is_hidden ()) {
$data [ 'grade' ][ 'class' ] = $class . ' dimmed_text' ;
$data [ 'grade' ][ 'content' ] = '-' ;
if ( $this -> canviewhidden ) {
$data [ 'grade' ][ 'content' ] = grade_format_gradevalue ( $gradeval ,
$grade_grade -> grade_item ,
true );
}
2011-01-18 16:24:41 +08:00
} else {
$data [ 'grade' ][ 'class' ] = $class ;
2014-08-29 09:48:44 +08:00
$data [ 'grade' ][ 'content' ] = grade_format_gradevalue ( $gradeval ,
2014-08-04 15:03:26 +08:00
$grade_grade -> grade_item ,
true );
2011-01-18 16:24:41 +08:00
}
2013-08-02 13:54:58 +08:00
$data [ 'grade' ][ 'headers' ] = " $header_cat $header_row grade " ;
2011-01-18 16:24:41 +08:00
}
// Range
if ( $this -> showrange ) {
$data [ 'range' ][ 'class' ] = $class ;
$data [ 'range' ][ 'content' ] = $grade_grade -> grade_item -> get_formatted_range ( GRADE_DISPLAY_TYPE_REAL , $this -> rangedecimals );
2013-08-02 13:54:58 +08:00
$data [ 'range' ][ 'headers' ] = " $header_cat $header_row range " ;
2011-01-18 16:24:41 +08:00
}
// Percentage
2010-02-12 03:39:40 +00:00
if ( $this -> showpercentage ) {
if ( $grade_grade -> grade_item -> needsupdate ) {
$data [ 'percentage' ][ 'class' ] = $class . ' gradingerror' ;
$data [ 'percentage' ][ 'content' ] = get_string ( 'error' );
2011-01-18 16:24:41 +08:00
} else if ( $grade_grade -> is_hidden ()) {
2014-08-19 12:53:22 +08:00
$data [ 'percentage' ][ 'class' ] = $class . ' dimmed_text' ;
2011-01-18 16:24:41 +08:00
$data [ 'percentage' ][ 'content' ] = '-' ;
2014-08-29 09:48:44 +08:00
if ( $this -> canviewhidden ) {
$data [ 'percentage' ][ 'content' ] = grade_format_gradevalue ( $gradeval , $grade_grade -> grade_item , true , GRADE_DISPLAY_TYPE_PERCENTAGE );
}
2010-02-12 03:39:40 +00:00
} else {
$data [ 'percentage' ][ 'class' ] = $class ;
$data [ 'percentage' ][ 'content' ] = grade_format_gradevalue ( $gradeval , $grade_grade -> grade_item , true , GRADE_DISPLAY_TYPE_PERCENTAGE );
}
2013-08-02 13:54:58 +08:00
$data [ 'percentage' ][ 'headers' ] = " $header_cat $header_row percentage " ;
2010-02-12 03:39:40 +00:00
}
2011-01-18 16:24:41 +08:00
// Lettergrade
if ( $this -> showlettergrade ) {
if ( $grade_grade -> grade_item -> needsupdate ) {
$data [ 'lettergrade' ][ 'class' ] = $class . ' gradingerror' ;
$data [ 'lettergrade' ][ 'content' ] = get_string ( 'error' );
} else if ( $grade_grade -> is_hidden ()) {
2014-08-19 12:53:22 +08:00
$data [ 'lettergrade' ][ 'class' ] = $class . ' dimmed_text' ;
2011-01-18 16:24:41 +08:00
if ( ! $this -> canviewhidden ) {
$data [ 'lettergrade' ][ 'content' ] = '-' ;
} else {
$data [ 'lettergrade' ][ 'content' ] = grade_format_gradevalue ( $gradeval , $grade_grade -> grade_item , true , GRADE_DISPLAY_TYPE_LETTER );
}
} else {
$data [ 'lettergrade' ][ 'class' ] = $class ;
$data [ 'lettergrade' ][ 'content' ] = grade_format_gradevalue ( $gradeval , $grade_grade -> grade_item , true , GRADE_DISPLAY_TYPE_LETTER );
}
2013-08-02 13:54:58 +08:00
$data [ 'lettergrade' ][ 'headers' ] = " $header_cat $header_row lettergrade " ;
2011-01-18 16:24:41 +08:00
}
// Rank
2010-02-12 03:39:40 +00:00
if ( $this -> showrank ) {
if ( $grade_grade -> grade_item -> needsupdate ) {
$data [ 'rank' ][ 'class' ] = $class . ' gradingerror' ;
$data [ 'rank' ][ 'content' ] = get_string ( 'error' );
} elseif ( $grade_grade -> is_hidden ()) {
2014-08-19 12:53:22 +08:00
$data [ 'rank' ][ 'class' ] = $class . ' dimmed_text' ;
2010-02-12 03:39:40 +00:00
$data [ 'rank' ][ 'content' ] = '-' ;
} else if ( is_null ( $gradeval )) {
// no grade, no rank
$data [ 'rank' ][ 'class' ] = $class ;
2009-04-16 07:16:44 +00:00
$data [ 'rank' ][ 'content' ] = '-' ;
2007-10-27 15:33:43 +00:00
2010-02-12 03:39:40 +00:00
} else {
/// find the number of users with a higher grade
$sql = " SELECT COUNT(DISTINCT(userid))
FROM { grade_grades }
WHERE finalgrade > ?
2011-01-18 16:24:41 +08:00
AND itemid = ?
AND hidden = 0 " ;
2010-02-12 03:39:40 +00:00
$rank = $DB -> count_records_sql ( $sql , array ( $grade_grade -> finalgrade , $grade_grade -> grade_item -> id )) + 1 ;
$data [ 'rank' ][ 'class' ] = $class ;
$data [ 'rank' ][ 'content' ] = " $rank / " . $this -> get_numusers ( false ); // total course users
}
2013-08-02 13:54:58 +08:00
$data [ 'rank' ][ 'headers' ] = " $header_cat $header_row rank " ;
2007-10-21 12:56:19 +00:00
}
2007-07-16 04:09:00 +00:00
2011-01-18 16:24:41 +08:00
// Average
if ( $this -> showaverage ) {
$data [ 'average' ][ 'class' ] = $class ;
if ( ! empty ( $this -> gtree -> items [ $eid ] -> avg )) {
$data [ 'average' ][ 'content' ] = $this -> gtree -> items [ $eid ] -> avg ;
} else {
$data [ 'average' ][ 'content' ] = '-' ;
}
2013-08-02 13:54:58 +08:00
$data [ 'average' ][ 'headers' ] = " $header_cat $header_row average " ;
2010-02-12 03:39:40 +00:00
}
2007-10-17 09:45:14 +00:00
2011-01-18 16:24:41 +08:00
// Feedback
if ( $this -> showfeedback ) {
if ( $grade_grade -> overridden > 0 AND ( $type == 'categoryitem' OR $type == 'courseitem' )) {
2012-03-04 12:21:03 +07:00
$data [ 'feedback' ][ 'class' ] = $classfeedback . ' feedbacktext' ;
2011-01-18 16:24:41 +08:00
$data [ 'feedback' ][ 'content' ] = get_string ( 'overridden' , 'grades' ) . ': ' . format_text ( $grade_grade -> feedback , $grade_grade -> feedbackformat );
} else if ( empty ( $grade_grade -> feedback ) or ( ! $this -> canviewhidden and $grade_grade -> is_hidden ())) {
2012-03-04 12:21:03 +07:00
$data [ 'feedback' ][ 'class' ] = $classfeedback . ' feedbacktext' ;
2011-01-18 16:24:41 +08:00
$data [ 'feedback' ][ 'content' ] = ' ' ;
} else {
2012-03-04 12:21:03 +07:00
$data [ 'feedback' ][ 'class' ] = $classfeedback . ' feedbacktext' ;
2011-01-18 16:24:41 +08:00
$data [ 'feedback' ][ 'content' ] = format_text ( $grade_grade -> feedback , $grade_grade -> feedbackformat );
}
2013-08-02 13:54:58 +08:00
$data [ 'feedback' ][ 'headers' ] = " $header_cat $header_row feedback " ;
2010-02-12 03:39:40 +00:00
}
2014-08-13 14:23:59 +08:00
// Contribution to the course total column.
if ( $this -> showcontributiontocoursetotal ) {
$data [ 'contributiontocoursetotal' ][ 'class' ] = $class ;
$data [ 'contributiontocoursetotal' ][ 'content' ] = '-' ;
$data [ 'contributiontocoursetotal' ][ 'headers' ] = " $header_cat $header_row contributiontocoursetotal " ;
2014-09-23 15:38:54 +08:00
2014-08-13 14:23:59 +08:00
}
2009-02-25 07:56:11 +00:00
}
2014-10-23 11:22:10 +08:00
// We collect the aggregation hints whether they are hidden or not.
if ( $this -> showcontributiontocoursetotal ) {
$hint [ 'grademax' ] = $grade_grade -> grade_item -> grademax ;
$hint [ 'grademin' ] = $grade_grade -> grade_item -> grademin ;
$hint [ 'grade' ] = $gradeval ;
$parent = $grade_object -> load_parent_category ();
if ( $grade_object -> is_category_item ()) {
$parent = $parent -> load_parent_category ();
}
$hint [ 'parent' ] = $parent -> load_grade_item () -> id ;
$this -> aggregationhints [ $grade_grade -> itemid ] = $hint ;
}
2007-07-16 04:09:00 +00:00
}
2007-10-08 23:09:10 +00:00
2009-02-25 07:56:11 +00:00
/// Category
if ( $type == 'category' ) {
$data [ 'leader' ][ 'class' ] = $class . ' ' . $alter . " d $depth b1t b2b b1l " ;
$data [ 'leader' ][ 'rowspan' ] = $element [ 'rowspan' ];
if ( $this -> switch ) { // alter style based on whether aggregation is first or last
$data [ 'itemname' ][ 'class' ] = $class . ' ' . $alter . " d $depth b1b b1t " ;
} else {
$data [ 'itemname' ][ 'class' ] = $class . ' ' . $alter . " d $depth b2t " ;
}
$data [ 'itemname' ][ 'colspan' ] = ( $this -> maxdepth - $depth + count ( $this -> tablecolumns ) - 1 );
$data [ 'itemname' ][ 'content' ] = $fullname ;
2013-08-02 13:54:58 +08:00
$data [ 'itemname' ][ 'celltype' ] = 'th' ;
$data [ 'itemname' ][ 'id' ] = " cat_ { $grade_object -> id } _ { $this -> user -> id } " ;
2009-02-25 07:56:11 +00:00
}
/// Add this row to the overall system
2014-10-02 18:35:10 +08:00
foreach ( $data as $key => $celldata ) {
$data [ $key ][ 'class' ] .= ' column-' . $key ;
}
2009-02-25 07:56:11 +00:00
$this -> tabledata [] = $data ;
/// Recursively iterate through all child elements
if ( isset ( $element [ 'children' ])) {
foreach ( $element [ 'children' ] as $key => $child ) {
2014-09-24 16:21:30 +08:00
$this -> fill_table_recursive ( $element [ 'children' ][ $key ]);
2014-09-23 15:38:54 +08:00
}
}
2014-09-24 13:22:41 +08:00
// Check we are showing this column, and we are looking at the root of the table.
// This should be the very last thing this fill_table_recursive function does.
2014-09-23 15:38:54 +08:00
if ( $this -> showcontributiontocoursetotal && ( $type == 'category' && $depth == 1 )) {
// We should have collected all the hints by now - walk the tree again and build the contributions column.
2014-09-24 16:21:30 +08:00
$this -> fill_contributions_column ( $element );
2014-09-23 15:38:54 +08:00
}
}
2014-09-24 13:22:41 +08:00
/**
* This function is called after the table has been built and the aggregationhints
* have been collected . We need this info to walk up the list of parents of each
* grade_item .
*
* @ param $element - An array containing the table data for the current row .
*/
2014-09-24 16:21:30 +08:00
public function fill_contributions_column ( $element ) {
2014-09-23 15:38:54 +08:00
2014-09-24 16:21:30 +08:00
// Recursively iterate through all child elements.
2014-09-23 15:38:54 +08:00
if ( isset ( $element [ 'children' ])) {
foreach ( $element [ 'children' ] as $key => $child ) {
2014-09-24 16:21:30 +08:00
$this -> fill_contributions_column ( $element [ 'children' ][ $key ]);
2014-09-23 15:38:54 +08:00
}
} else if ( $element [ 'type' ] == 'item' ) {
2014-09-24 13:22:41 +08:00
// This is a grade item (We don't do this for categories or we would double count).
2014-09-23 15:38:54 +08:00
$grade_object = $element [ 'object' ];
$itemid = $grade_object -> id ;
2014-09-24 13:22:41 +08:00
// Ignore anything with no hint - e.g. a hidden row.
2014-09-24 16:21:30 +08:00
if ( isset ( $this -> aggregationhints [ $itemid ])) {
2014-09-23 15:38:54 +08:00
2014-09-24 13:22:41 +08:00
// Normalise the gradeval.
2014-09-26 17:32:08 +08:00
$gradecat = $grade_object -> load_parent_category ();
if ( $gradecat -> aggregation == GRADE_AGGREGATE_SUM ) {
2014-10-13 15:06:45 +08:00
// Natural aggregation/Sum of grades does not consider the mingrade, cannot traditionnally normalise it.
2014-09-26 17:32:08 +08:00
$graderange = $this -> aggregationhints [ $itemid ][ 'grademax' ];
$gradeval = $this -> aggregationhints [ $itemid ][ 'grade' ] / $graderange ;
} else {
2014-10-13 15:06:45 +08:00
$gradeval = grade_grade :: standardise_score ( $this -> aggregationhints [ $itemid ][ 'grade' ],
$this -> aggregationhints [ $itemid ][ 'grademin' ], $this -> aggregationhints [ $itemid ][ 'grademax' ], 0 , 1 );
2014-09-26 17:32:08 +08:00
}
2014-09-23 15:38:54 +08:00
2014-09-24 13:22:41 +08:00
// Multiply the normalised value by the weight
// of all the categories higher in the tree.
2014-10-20 15:24:45 +08:00
$parent = null ;
2014-09-23 15:38:54 +08:00
do {
2014-09-24 16:21:30 +08:00
if ( ! is_null ( $this -> aggregationhints [ $itemid ][ 'weight' ])) {
$gradeval *= $this -> aggregationhints [ $itemid ][ 'weight' ];
2014-10-20 15:24:45 +08:00
} else if ( empty ( $parent )) {
// If we are in the first loop, and the weight is null, then we cannot calculate the contribution.
$gradeval = null ;
break ;
2014-09-23 15:38:54 +08:00
}
2014-09-24 13:22:41 +08:00
// The second part of this if is to prevent infinite loops
// in case of crazy data.
2014-09-24 16:21:30 +08:00
if ( isset ( $this -> aggregationhints [ $itemid ][ 'parent' ]) &&
$this -> aggregationhints [ $itemid ][ 'parent' ] != $itemid ) {
$parent = $this -> aggregationhints [ $itemid ][ 'parent' ];
2014-09-23 15:38:54 +08:00
$itemid = $parent ;
} else {
2014-09-24 16:21:30 +08:00
// We are at the top of the tree.
2014-09-23 15:38:54 +08:00
$parent = false ;
}
} while ( $parent );
2014-10-21 13:34:08 +08:00
2014-10-20 15:24:45 +08:00
// Finally multiply by the course grademax.
if ( ! is_null ( $gradeval )) {
// Convert to percent.
$gradeval *= 100 ;
}
2014-09-23 15:38:54 +08:00
2014-09-24 13:22:41 +08:00
// Now we need to loop through the "built" table data and update the
// contributions column for the current row.
2014-09-23 15:38:54 +08:00
$header_row = " row_ { $grade_object -> id } _ { $this -> user -> id } " ;
foreach ( $this -> tabledata as $key => $row ) {
2014-09-24 16:21:30 +08:00
if ( isset ( $row [ 'itemname' ]) && ( $row [ 'itemname' ][ 'id' ] == $header_row )) {
2014-09-24 13:22:41 +08:00
// Found it - update the column.
2014-10-20 15:24:45 +08:00
$content = '-' ;
if ( ! is_null ( $gradeval )) {
$decimals = $grade_object -> get_decimals ();
$content = format_float ( $gradeval , $decimals , true ) . ' %' ;
}
$this -> tabledata [ $key ][ 'contributiontocoursetotal' ][ 'content' ] = $content ;
2014-09-23 15:38:54 +08:00
break ;
}
}
2009-02-25 07:56:11 +00:00
}
}
2007-07-16 04:09:00 +00:00
}
/**
* Prints or returns the HTML from the flexitable .
* @ param bool $return Whether or not to return the data instead of printing it directly .
* @ return string
*/
2008-06-03 16:10:57 +00:00
public function print_table ( $return = false ) {
2009-02-25 07:56:11 +00:00
$maxspan = $this -> maxdepth ;
/// Build table structure
$html = "
2013-08-02 14:40:23 +08:00
< table cellspacing = '0'
cellpadding = '0'
2013-08-05 11:20:32 +08:00
summary = '" . s($this->get_lang_string(' tablesummary ', ' gradereport_user ')) . "'
2013-08-02 14:40:23 +08:00
class = 'boxaligncenter generaltable user-grade' >
2009-02-25 07:56:11 +00:00
< thead >
< tr >
2014-10-02 18:35:10 +08:00
< th id = '".$this->tablecolumns[0]."' class = \ " header column- { $this -> tablecolumns [ 0 ] } \" colspan=' $maxspan '> " . $this -> tableheaders [ 0 ] . " </th> \n " ;
2009-02-25 07:56:11 +00:00
for ( $i = 1 ; $i < count ( $this -> tableheaders ); $i ++ ) {
2014-10-02 18:35:10 +08:00
$html .= " <th id=' " . $this -> tablecolumns [ $i ] . " ' class= \" header column- { $this -> tablecolumns [ $i ] } \" > " . $this -> tableheaders [ $i ] . " </th> \n " ;
2009-02-25 07:56:11 +00:00
}
$html .= "
</ tr >
</ thead >
< tbody > \n " ;
/// Print out the table data
for ( $i = 0 ; $i < count ( $this -> tabledata ); $i ++ ) {
$html .= " <tr> \n " ;
if ( isset ( $this -> tabledata [ $i ][ 'leader' ])) {
$rowspan = $this -> tabledata [ $i ][ 'leader' ][ 'rowspan' ];
$class = $this -> tabledata [ $i ][ 'leader' ][ 'class' ];
$html .= " <td class=' $class ' rowspan=' $rowspan '></td> \n " ;
}
for ( $j = 0 ; $j < count ( $this -> tablecolumns ); $j ++ ) {
$name = $this -> tablecolumns [ $j ];
$class = ( isset ( $this -> tabledata [ $i ][ $name ][ 'class' ])) ? $this -> tabledata [ $i ][ $name ][ 'class' ] : '' ;
$colspan = ( isset ( $this -> tabledata [ $i ][ $name ][ 'colspan' ])) ? " colspan=' " . $this -> tabledata [ $i ][ $name ][ 'colspan' ] . " ' " : '' ;
$content = ( isset ( $this -> tabledata [ $i ][ $name ][ 'content' ])) ? $this -> tabledata [ $i ][ $name ][ 'content' ] : null ;
2013-08-02 13:54:58 +08:00
$celltype = ( isset ( $this -> tabledata [ $i ][ $name ][ 'celltype' ])) ? $this -> tabledata [ $i ][ $name ][ 'celltype' ] : 'td' ;
$id = ( isset ( $this -> tabledata [ $i ][ $name ][ 'id' ])) ? " id=' { $this -> tabledata [ $i ][ $name ][ 'id' ] } ' " : '' ;
$headers = ( isset ( $this -> tabledata [ $i ][ $name ][ 'headers' ])) ? " headers=' { $this -> tabledata [ $i ][ $name ][ 'headers' ] } ' " : '' ;
2009-02-25 07:56:11 +00:00
if ( isset ( $content )) {
2013-08-02 13:54:58 +08:00
$html .= " < $celltype $id $headers class=' $class ' $colspan > $content </ $celltype > \n " ;
2009-02-25 07:56:11 +00:00
}
}
$html .= " </tr> \n " ;
}
$html .= " </tbody></table> " ;
2007-07-16 04:09:00 +00:00
if ( $return ) {
return $html ;
} else {
echo $html ;
}
}
/**
* Processes the data sent by the form ( grades and feedbacks ) .
* @ var array $data
* @ return bool Success or Failure ( array of errors ) .
*/
2009-04-16 07:16:44 +00:00
function process_data ( $data ) {
2008-06-03 16:10:57 +00:00
}
2009-04-16 07:16:44 +00:00
function process_action ( $target , $action ) {
2007-07-16 04:09:00 +00:00
}
2011-01-18 16:24:41 +08:00
/**
* Builds the grade item averages .
*/
function calculate_averages () {
global $USER , $DB ;
if ( $this -> showaverage ) {
2013-07-09 13:34:39 +08:00
// This settings are actually grader report settings (not user report)
2011-01-18 16:24:41 +08:00
// however we're using them as having two separate but identical settings the
2013-07-09 13:34:39 +08:00
// user would have to keep in sync would be annoying.
2011-01-18 16:24:41 +08:00
$averagesdisplaytype = $this -> get_pref ( 'averagesdisplaytype' );
$averagesdecimalpoints = $this -> get_pref ( 'averagesdecimalpoints' );
$meanselection = $this -> get_pref ( 'meanselection' );
$shownumberofgrades = $this -> get_pref ( 'shownumberofgrades' );
$avghtml = '' ;
$groupsql = $this -> groupsql ;
$groupwheresql = $this -> groupwheresql ;
$totalcount = $this -> get_numusers ( false );
2013-07-09 13:34:39 +08:00
// We want to query both the current context and parent contexts.
list ( $relatedctxsql , $relatedctxparams ) = $DB -> get_in_or_equal ( $this -> context -> get_parent_context_ids ( true ), SQL_PARAMS_NAMED , 'relatedctx' );
// Limit to users with a gradeable role ie students.
2011-01-18 16:24:41 +08:00
list ( $gradebookrolessql , $gradebookrolesparams ) = $DB -> get_in_or_equal ( explode ( ',' , $this -> gradebookroles ), SQL_PARAMS_NAMED , 'grbr0' );
2013-07-09 13:34:39 +08:00
// Limit to users with an active enrolment.
2011-01-18 16:24:41 +08:00
list ( $enrolledsql , $enrolledparams ) = get_enrolled_sql ( $this -> context );
2013-07-09 13:34:39 +08:00
$params = array_merge ( $this -> groupwheresql_params , $gradebookrolesparams , $enrolledparams , $relatedctxparams );
2011-01-18 16:24:41 +08:00
$params [ 'courseid' ] = $this -> courseid ;
// find sums of all grade items in course
$sql = " SELECT gg.itemid, SUM(gg.finalgrade) AS sum
FROM { grade_items } gi
2011-04-04 11:27:09 +02:00
JOIN { grade_grades } gg ON gg . itemid = gi . id
JOIN { user } u ON u . id = gg . userid
JOIN ( $enrolledsql ) je ON je . id = gg . userid
JOIN (
SELECT DISTINCT ra . userid
FROM { role_assignments } ra
WHERE ra . roleid $gradebookrolessql
2013-07-09 13:34:39 +08:00
AND ra . contextid $relatedctxsql
2011-04-04 11:27:09 +02:00
) rainner ON rainner . userid = u . id
2011-01-18 16:24:41 +08:00
$groupsql
WHERE gi . courseid = : courseid
2011-04-04 11:27:09 +02:00
AND u . deleted = 0
AND gg . finalgrade IS NOT NULL
AND gg . hidden = 0
$groupwheresql
2011-01-18 16:24:41 +08:00
GROUP BY gg . itemid " ;
$sum_array = array ();
2011-01-30 13:43:06 +01:00
$sums = $DB -> get_recordset_sql ( $sql , $params );
foreach ( $sums as $itemid => $csum ) {
$sum_array [ $itemid ] = $csum -> sum ;
2011-01-18 16:24:41 +08:00
}
2011-01-30 13:43:06 +01:00
$sums -> close ();
2011-01-18 16:24:41 +08:00
$columncount = 0 ;
// Empty grades must be evaluated as grademin, NOT always 0
// This query returns a count of ungraded grades (NULL finalgrade OR no matching record in grade_grades table)
// No join condition when joining grade_items and user to get a grade item row for every user
// Then left join with grade_grades and look for rows with null final grade (which includes grade items with no grade_grade)
$sql = " SELECT gi.id, COUNT(u.id) AS count
FROM { grade_items } gi
2011-11-10 11:42:21 +08:00
JOIN { user } u ON u . deleted = 0
2011-04-04 11:27:09 +02:00
JOIN ( $enrolledsql ) je ON je . id = u . id
JOIN (
SELECT DISTINCT ra . userid
FROM { role_assignments } ra
WHERE ra . roleid $gradebookrolessql
2013-07-09 13:34:39 +08:00
AND ra . contextid $relatedctxsql
2011-04-04 11:27:09 +02:00
) rainner ON rainner . userid = u . id
2011-01-18 17:17:14 +08:00
LEFT JOIN { grade_grades } gg
2011-11-10 11:42:21 +08:00
ON ( gg . itemid = gi . id AND gg . userid = u . id AND gg . finalgrade IS NOT NULL AND gg . hidden = 0 )
2011-01-18 16:24:41 +08:00
$groupsql
2011-04-04 11:27:09 +02:00
WHERE gi . courseid = : courseid
AND gg . finalgrade IS NULL
$groupwheresql
GROUP BY gi . id " ;
2011-01-18 16:24:41 +08:00
$ungraded_counts = $DB -> get_records_sql ( $sql , $params );
foreach ( $this -> gtree -> items as $itemid => $unused ) {
if ( ! empty ( $this -> gtree -> items [ $itemid ] -> avg )) {
continue ;
}
$item = $this -> gtree -> items [ $itemid ];
if ( $item -> needsupdate ) {
$avghtml .= '<td class="cell c' . $columncount ++. '"><span class="gradingerror">' . get_string ( 'error' ) . '</span></td>' ;
continue ;
}
if ( empty ( $sum_array [ $item -> id ])) {
$sum_array [ $item -> id ] = 0 ;
}
if ( empty ( $ungraded_counts [ $itemid ])) {
$ungraded_count = 0 ;
} else {
$ungraded_count = $ungraded_counts [ $itemid ] -> count ;
}
//do they want the averages to include all grade items
if ( $meanselection == GRADE_REPORT_MEAN_GRADED ) {
$mean_count = $totalcount - $ungraded_count ;
} else { // Bump up the sum by the number of ungraded items * grademin
$sum_array [ $item -> id ] += ( $ungraded_count * $item -> grademin );
$mean_count = $totalcount ;
}
// Determine which display type to use for this average
if ( ! empty ( $USER -> gradeediting ) && $USER -> gradeediting [ $this -> courseid ]) {
$displaytype = GRADE_DISPLAY_TYPE_REAL ;
} else if ( $averagesdisplaytype == GRADE_REPORT_PREFERENCE_INHERIT ) { // no ==0 here, please resave the report and user preferences
$displaytype = $item -> get_displaytype ();
} else {
$displaytype = $averagesdisplaytype ;
}
// Override grade_item setting if a display preference (not inherit) was set for the averages
if ( $averagesdecimalpoints == GRADE_REPORT_PREFERENCE_INHERIT ) {
$decimalpoints = $item -> get_decimals ();
} else {
$decimalpoints = $averagesdecimalpoints ;
}
if ( empty ( $sum_array [ $item -> id ]) || $mean_count == 0 ) {
$this -> gtree -> items [ $itemid ] -> avg = '-' ;
} else {
$sum = $sum_array [ $item -> id ];
$avgradeval = $sum / $mean_count ;
$gradehtml = grade_format_gradevalue ( $avgradeval , $item , true , $displaytype , $decimalpoints );
$numberofgrades = '' ;
if ( $shownumberofgrades ) {
$numberofgrades = " ( $mean_count ) " ;
}
$this -> gtree -> items [ $itemid ] -> avg = $gradehtml . $numberofgrades ;
}
}
}
}
2015-03-30 10:31:29 +02:00
/**
* Trigger the grade_report_viewed event
*
* @ since Moodle 2.9
*/
public function viewed () {
$event = \gradereport_user\event\grade_report_viewed :: create (
array (
'context' => $this -> context ,
'courseid' => $this -> courseid ,
'relateduserid' => $this -> user -> id ,
)
);
$event -> trigger ();
}
2007-10-27 15:33:43 +00:00
}
function grade_report_user_settings_definition ( & $mform ) {
global $CFG ;
$options = array ( - 1 => get_string ( 'default' , 'grades' ),
0 => get_string ( 'hide' ),
1 => get_string ( 'show' ));
2007-10-27 20:37:22 +00:00
if ( empty ( $CFG -> grade_report_user_showrank )) {
2007-10-27 15:33:43 +00:00
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 0 ]);
} else {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 1 ]);
}
$mform -> addElement ( 'select' , 'report_user_showrank' , get_string ( 'showrank' , 'grades' ), $options );
2010-06-25 17:19:34 +00:00
$mform -> addHelpButton ( 'report_user_showrank' , 'showrank' , 'grades' );
2007-10-27 15:33:43 +00:00
2008-10-08 11:06:05 +00:00
if ( empty ( $CFG -> grade_report_user_showpercentage )) {
2008-10-13 08:44:10 +00:00
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 0 ]);
2009-02-25 07:56:11 +00:00
} else {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 1 ]);
2008-10-08 11:06:05 +00:00
}
$mform -> addElement ( 'select' , 'report_user_showpercentage' , get_string ( 'showpercentage' , 'grades' ), $options );
2010-06-21 08:39:27 +00:00
$mform -> addHelpButton ( 'report_user_showpercentage' , 'showpercentage' , 'grades' );
2008-10-08 11:06:05 +00:00
2011-01-18 16:24:41 +08:00
if ( empty ( $CFG -> grade_report_user_showgrade )) {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 0 ]);
} else {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 1 ]);
}
$mform -> addElement ( 'select' , 'report_user_showgrade' , get_string ( 'showgrade' , 'grades' ), $options );
if ( empty ( $CFG -> grade_report_user_showfeedback )) {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 0 ]);
} else {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 1 ]);
}
$mform -> addElement ( 'select' , 'report_user_showfeedback' , get_string ( 'showfeedback' , 'grades' ), $options );
if ( empty ( $CFG -> grade_report_user_showweight )) {
2014-10-10 14:55:37 +08:00
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 0 ]);
2014-10-15 13:39:36 +08:00
} else {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 1 ]);
2011-01-18 16:24:41 +08:00
}
$mform -> addElement ( 'select' , 'report_user_showweight' , get_string ( 'showweight' , 'grades' ), $options );
if ( empty ( $CFG -> grade_report_user_showaverage )) {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 0 ]);
} else {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 1 ]);
}
$mform -> addElement ( 'select' , 'report_user_showaverage' , get_string ( 'showaverage' , 'grades' ), $options );
$mform -> addHelpButton ( 'report_user_showaverage' , 'showaverage' , 'grades' );
if ( empty ( $CFG -> grade_report_user_showlettergrade )) {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 0 ]);
} else {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 1 ]);
}
$mform -> addElement ( 'select' , 'report_user_showlettergrade' , get_string ( 'showlettergrade' , 'grades' ), $options );
2014-08-13 14:23:59 +08:00
if ( empty ( $CFG -> grade_report_user_showcontributiontocoursetotal )) {
2014-10-15 13:39:36 +08:00
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 0 ]);
2014-08-13 14:23:59 +08:00
} else {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ $CFG -> grade_report_user_showcontributiontocoursetotal ]);
}
$mform -> addElement ( 'select' , 'report_user_showcontributiontocoursetotal' , get_string ( 'showcontributiontocoursetotal' , 'grades' ), $options );
$mform -> addHelpButton ( 'report_user_showcontributiontocoursetotal' , 'showcontributiontocoursetotal' , 'grades' );
2011-01-18 16:24:41 +08:00
if ( empty ( $CFG -> grade_report_user_showrange )) {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 0 ]);
} else {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 1 ]);
}
$mform -> addElement ( 'select' , 'report_user_showrange' , get_string ( 'showrange' , 'grades' ), $options );
$options = array ( 0 => 0 , 1 => 1 , 2 => 2 , 3 => 3 , 4 => 4 , 5 => 5 );
if ( ! empty ( $CFG -> grade_report_user_rangedecimals )) {
$options [ - 1 ] = $options [ $CFG -> grade_report_user_rangedecimals ];
}
$mform -> addElement ( 'select' , 'report_user_rangedecimals' , get_string ( 'rangedecimals' , 'grades' ), $options );
2007-10-27 15:33:43 +00:00
$options = array ( - 1 => get_string ( 'default' , 'grades' ),
2009-05-07 07:38:02 +00:00
0 => get_string ( 'shownohidden' , 'grades' ),
2007-10-30 21:25:50 +00:00
1 => get_string ( 'showhiddenuntilonly' , 'grades' ),
2009-05-07 07:38:02 +00:00
2 => get_string ( 'showallhidden' , 'grades' ));
2007-10-27 15:33:43 +00:00
2007-10-27 20:37:22 +00:00
if ( empty ( $CFG -> grade_report_user_showhiddenitems )) {
2007-10-27 15:33:43 +00:00
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 0 ]);
} else {
2009-05-07 07:38:02 +00:00
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ $CFG -> grade_report_user_showhiddenitems ]);
2007-10-27 15:33:43 +00:00
}
$mform -> addElement ( 'select' , 'report_user_showhiddenitems' , get_string ( 'showhiddenitems' , 'grades' ), $options );
2010-06-21 06:57:46 +00:00
$mform -> addHelpButton ( 'report_user_showhiddenitems' , 'showhiddenitems' , 'grades' );
2010-02-08 06:27:04 +00:00
//showtotalsifcontainhidden
$options = array ( - 1 => get_string ( 'default' , 'grades' ),
GRADE_REPORT_HIDE_TOTAL_IF_CONTAINS_HIDDEN => get_string ( 'hide' ),
GRADE_REPORT_SHOW_TOTAL_IF_CONTAINS_HIDDEN => get_string ( 'hidetotalshowexhiddenitems' , 'grades' ),
GRADE_REPORT_SHOW_REAL_TOTAL_IF_CONTAINS_HIDDEN => get_string ( 'hidetotalshowinchiddenitems' , 'grades' ) );
if ( empty ( $CFG -> grade_report_user_showtotalsifcontainhidden )) {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ 0 ]);
} else {
$options [ - 1 ] = get_string ( 'defaultprev' , 'grades' , $options [ $CFG -> grade_report_user_showtotalsifcontainhidden ]);
}
$mform -> addElement ( 'select' , 'report_user_showtotalsifcontainhidden' , get_string ( 'hidetotalifhiddenitems' , 'grades' ), $options );
2010-06-07 09:56:33 +00:00
$mform -> addHelpButton ( 'report_user_showtotalsifcontainhidden' , 'hidetotalifhiddenitems' , 'grades' );
2014-08-13 14:23:59 +08:00
2007-10-28 17:15:00 +00:00
}
2014-08-11 11:53:06 +08:00
/**
* Profile report callback .
*
* @ param object $course The course .
* @ param object $user The user .
* @ param boolean $viewasuser True when we are viewing this as the targetted user sees it .
*/
function grade_report_user_profilereport ( $course , $user , $viewasuser = false ) {
2009-09-04 03:12:01 +00:00
global $OUTPUT ;
2007-10-28 17:15:00 +00:00
if ( ! empty ( $course -> showgrades )) {
2012-07-24 14:04:40 +08:00
$context = context_course :: instance ( $course -> id );
2007-10-28 17:15:00 +00:00
//first make sure we have proper final grades - this must be done before constructing of the grade tree
grade_regrade_final_grades ( $course -> id );
/// return tracking object
$gpr = new grade_plugin_return ( array ( 'type' => 'report' , 'plugin' => 'user' , 'courseid' => $course -> id , 'userid' => $user -> id ));
// Create a report instance
2014-08-11 11:53:06 +08:00
$report = new grade_report_user ( $course -> id , $gpr , $context , $user -> id , $viewasuser );
2007-07-16 04:09:00 +00:00
2007-10-28 17:15:00 +00:00
// print the page
echo '<div class="grade-report-user">' ; // css fix to share styles with real report page
MDL-23071 standardising gradebook plugin names
AMOS BEGIN
MOV [modulename,gradeimport_csv],[pluginname,gradeimport_csv]
MOV [modulename,gradeimport_xml],[pluginname,gradeimport_xml]
MOV [modulename,gradeexport_ods],[pluginname,gradeexport_ods]
MOV [modulename,gradeexport_txt],[pluginname,gradeexport_txt]
MOV [modulename,gradeexport_xls],[pluginname,gradeexport_xls]
MOV [modulename,gradeexport_xml],[pluginname,gradeexport_xml]
MOV [modulename,gradereport_grader],[pluginname,gradereport_grader]
MOV [modulename,gradereport_outcomes],[pluginname,gradereport_outcomes]
MOV [modulename,gradereport_overview],[pluginname,gradereport_overview]
MOV [modulename,gradereport_user],[pluginname,gradereport_user]
AMOS END
2010-07-04 13:08:11 +00:00
echo $OUTPUT -> heading ( get_string ( 'pluginname' , 'gradereport_user' ) . ' - ' . fullname ( $report -> user ));
2007-10-28 17:15:00 +00:00
if ( $report -> fill_table ()) {
echo $report -> print_table ( true );
}
echo '</div>' ;
}
2007-07-16 04:09:00 +00:00
}
2007-10-28 17:15:00 +00:00
2009-11-01 12:11:29 +00:00