123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * Class to select, sort and transform object data into array data,
- * used for the teacher's evaluation results view
- * @author Bert Steppé
- * @package chamilo.gradebook
- */
- /**
- * Class
- * @package chamilo.gradebook
- */
- class ResultsDataGenerator
- {
- // Sorting types constants
- const RDG_SORT_LASTNAME = 1;
- const RDG_SORT_FIRSTNAME = 2;
- const RDG_SORT_SCORE = 4;
- const RDG_SORT_MASK = 8;
- const RDG_SORT_ASC = 16;
- const RDG_SORT_DESC = 32;
- private $evaluation;
- private $results;
- private $is_course_ind;
- private $include_edit;
- /**
- * Constructor
- */
- function ResultsDataGenerator ( $evaluation,
- $results = array(),
- $include_edit = false) {
- $this->evaluation = $evaluation;
- $this->results = (isset($results) ? $results : array());
- }
- /**
- * Get total number of results (rows)
- */
- public function get_total_results_count () {
- return count($this->results);
- }
- /**
- * Get actual array data
- * @return array 2-dimensional array - each array contains the elements:
- * 0 ['id'] : user id
- * 1 ['result_id'] : result id
- * 2 ['lastname'] : user lastname
- * 3 ['firstname'] : user firstname
- * 4 ['score'] : student's score
- * 5 ['display'] : custom score display (only if custom scoring enabled)
- */
- public function get_data ($sorting = 0, $start = 0, $count = null, $ignore_score_color = false, $pdf=false) {
- // do some checks on count, redefine if invalid value
- $number_decimals = api_get_setting('gradebook_number_decimals');
- if (!isset($count)) {
- $count = count ($this->results) - $start;
- }
- if ($count < 0) {
- $count = 0;
- }
- $scoredisplay = ScoreDisplay :: instance();
- // generate actual data array
- $table = array();
- foreach($this->results as $result) {
- $user = array();
- $info = api_get_user_info($result->get_user_id());
- $user['id'] = $result->get_user_id();
- if ($pdf){
- $user['username'] = $info['username'];
- }
- $user['result_id'] = $result->get_id();
- $user['lastname'] = $info['lastname'];
- $user['firstname'] = $info['firstname'];
- if ($pdf) {
- $user['score'] = $result->get_score();
- } else {
- $user['score'] = $this->get_score_display($result->get_score(),true, $ignore_score_color);
- }
- $user['percentage_score'] = intval($scoredisplay->display_score(array($result->get_score(), $this->evaluation->get_max()), SCORE_PERCENT, SCORE_BOTH, true));
- if ($pdf && $number_decimals == null){
- $user['scoreletter'] = $result->get_score();
- }
- if ($scoredisplay->is_custom()) {
- $user['display'] = $this->get_score_display($result->get_score(), false, $ignore_score_color);
- }
- $table[] = $user;
- }
- // sort array
- if ($sorting & self :: RDG_SORT_LASTNAME) {
- usort($table, array('ResultsDataGenerator', 'sort_by_last_name'));
- } elseif ($sorting & self :: RDG_SORT_FIRSTNAME) {
- usort($table, array('ResultsDataGenerator', 'sort_by_first_name'));
- } elseif ($sorting & self :: RDG_SORT_SCORE) {
- usort($table, array('ResultsDataGenerator', 'sort_by_score'));
- } elseif ($sorting & self :: RDG_SORT_MASK) {
- usort($table, array('ResultsDataGenerator', 'sort_by_mask'));
- }
- if ($sorting & self :: RDG_SORT_DESC) {
- $table = array_reverse($table);
- }
- $return = array_slice($table, $start, $count);
- return $return;
- }
- /**
- * Re-formats the score to show percentage ("2/4 (50 %)") or letters ("A")
- * @param float Current absolute score (max score is taken from $this->evaluation->get_max()
- * @param bool Whether we want the real score (2/4 (50 %)) or the transformation (A, B, C, etc)
- * @param bool Whether we want to ignore the score color
- * @result string The score as we want to show it
- */
- private function get_score_display ($score, $realscore, $ignore_score_color = false) {
- if ($score != null) {
- $scoredisplay = ScoreDisplay :: instance();
- $type = SCORE_CUSTOM;
- if ($realscore === true) {
- $type = SCORE_DIV_PERCENT ;
- }
- return $scoredisplay->display_score(array($score, $this->evaluation->get_max()), $type, SCORE_BOTH, $ignore_score_color);
- }
- return '';
- }
- // Sort functions - used internally
- function sort_by_last_name($item1, $item2) {
- return api_strcmp($item1['lastname'], $item2['lastname']);
- }
- function sort_by_first_name($item1, $item2) {
- return api_strcmp($item1['firstname'], $item2['firstname']);
- }
- function sort_by_score($item1, $item2) {
- if ($item1['percentage_score'] == $item2['percentage_score']) {
- return 0;
- } else {
- return ($item1['percentage_score'] < $item2['percentage_score'] ? -1 : 1);
- }
- }
- function sort_by_mask ($item1, $item2) {
- $score1 = (isset($item1['score']) ? array($item1['score'],$this->evaluation->get_max()) : null);
- $score2 = (isset($item2['score']) ? array($item2['score'],$this->evaluation->get_max()) : null);
- return ScoreDisplay :: compare_scores_by_custom_display($score1, $score2);
- }
- }
|