1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * Class FlatViewDataGenerator
- * Class to select, sort and transform object data into array data,
- * used for the teacher's flat view.
- *
- * @author Bert Steppé
- *
- * @package chamilo.gradebook
- */
- class FlatViewDataGenerator
- {
- // Sorting types constants
- const FVDG_SORT_LASTNAME = 1;
- const FVDG_SORT_FIRSTNAME = 2;
- const FVDG_SORT_ASC = 4;
- const FVDG_SORT_DESC = 8;
- public $params;
- /** @var Category */
- public $category;
- private $users;
- private $evals;
- private $links;
- private $evals_links;
- private $mainCourseCategory;
- /**
- * @param array $users
- * @param array $evals
- * @param array $links
- * @param array $params
- * @param Category|null $mainCourseCategory
- */
- public function __construct(
- $users = [],
- $evals = [],
- $links = [],
- $params = [],
- $mainCourseCategory = null
- ) {
- $this->users = isset($users) ? $users : [];
- $this->evals = isset($evals) ? $evals : [];
- $this->links = isset($links) ? $links : [];
- $this->evals_links = array_merge($this->evals, $this->links);
- $this->params = $params;
- $this->mainCourseCategory = $mainCourseCategory;
- }
- /**
- * @return Category
- */
- public function getMainCourseCategory()
- {
- return $this->mainCourseCategory;
- }
- /**
- * Get total number of users (rows).
- *
- * @return int
- */
- public function get_total_users_count()
- {
- return count($this->users);
- }
- /**
- * Get total number of evaluations/links (columns) (the 2 users columns not included).
- *
- * @return int
- */
- public function get_total_items_count()
- {
- return count($this->evals_links);
- }
- /**
- * Get array containing column header names (incl user columns).
- *
- * @param int $items_start Start item offset
- * @param int $items_count Number of items to get
- * @param bool $show_detail whether to show the details or not
- *
- * @return array List of headers
- */
- public function get_header_names($items_start = 0, $items_count = null, $show_detail = false)
- {
- $headers = [];
- if (isset($this->params['show_official_code']) && $this->params['show_official_code']) {
- $headers[] = get_lang('Code');
- }
- if (isset($this->params['join_firstname_lastname']) && $this->params['join_firstname_lastname']) {
- if (api_is_western_name_order()) {
- $headers[] = get_lang('First Name and Last Name');
- } else {
- $headers[] = get_lang('Last Name and First Name');
- }
- } else {
- if (api_is_western_name_order()) {
- $headers[] = get_lang('First name');
- $headers[] = get_lang('Last name');
- } else {
- $headers[] = get_lang('Last name');
- $headers[] = get_lang('First name');
- }
- }
- $headers[] = get_lang('Username');
- $this->addExtraFieldColumnsHeaders($headers);
- if (!isset($items_count)) {
- $items_count = count($this->evals_links) - $items_start;
- }
- $parent_id = $this->category->get_parent_id();
- if ($parent_id == 0 ||
- isset($this->params['only_subcat']) &&
- $this->params['only_subcat'] == $this->category->get_id()
- ) {
- $main_weight = $this->category->get_weight();
- } else {
- $main_cat = Category::load($parent_id, null, null);
- $main_weight = $main_cat[0]->get_weight();
- }
- //@todo move these in a function
- $sum_categories_weight_array = [];
- $mainCategoryId = null;
- $mainCourseCategory = $this->getMainCourseCategory();
- if (!empty($mainCourseCategory)) {
- $mainCategoryId = $mainCourseCategory->get_id();
- }
- // No category was added
- $course_code = api_get_course_id();
- $session_id = api_get_session_id();
- $model = ExerciseLib::getCourseScoreModel();
- $allcat = $this->category->get_subcategories(
- null,
- $course_code,
- $session_id,
- 'ORDER BY id'
- );
- $evaluationsAdded = [];
- if ($parent_id == 0 && !empty($allcat)) {
- // Means there are any subcategory
- /** @var Category $sub_cat */
- foreach ($allcat as $sub_cat) {
- $sub_cat_weight = round(100 * $sub_cat->get_weight() / $main_weight, 1);
- $add_weight = " $sub_cat_weight %";
- $mainHeader = Display::url(
- $sub_cat->get_name(),
- api_get_self().'?selectcat='.$sub_cat->get_id().'&'.api_get_cidreq()
- ).$add_weight;
- if (api_get_setting('gradebook_detailed_admin_view') === 'true') {
- $links = $sub_cat->get_links();
- $evaluations = $sub_cat->get_evaluations();
- /** @var ExerciseLink $link */
- $linkNameList = [];
- foreach ($links as $link) {
- $linkNameList[] = $link->get_name();
- }
- $evalNameList = [];
- foreach ($evaluations as $evaluation) {
- $evalNameList[] = $evaluation->get_name();
- }
- $finalList = array_merge($linkNameList, $evalNameList);
- if (!empty($finalList)) {
- $finalList[] = get_lang('Average');
- }
- $list = [];
- $list['items'] = $finalList;
- $list['header'] = '<span class="text-center">'.$mainHeader.'</span>';
- $headers[] = $list;
- } else {
- $headers[] = '<span class="text-center">'.$mainHeader.'</span>';
- }
- }
- } else {
- if (!isset($this->params['only_total_category']) ||
- (isset($this->params['only_total_category']) &&
- $this->params['only_total_category'] == false)
- ) {
- for ($count = 0; ($count < $items_count) && ($items_start + $count < count($this->evals_links)); $count++) {
- /** @var AbstractLink $item */
- $item = $this->evals_links[$count + $items_start];
- $weight = round(100 * $item->get_weight() / $main_weight, 1);
- $label = $item->get_name().' '.$weight.' % ';
- if (!empty($model)) {
- $label = $item->get_name();
- }
- $headers[] = $label;
- $evaluationsAdded[] = $item->get_id();
- }
- }
- }
- if (!empty($mainCategoryId)) {
- for ($count = 0; ($count < $items_count) && ($items_start + $count < count($this->evals_links)); $count++) {
- /** @var AbstractLink $item */
- $item = $this->evals_links[$count + $items_start];
- if ($mainCategoryId == $item->get_category_id() &&
- !in_array($item->get_id(), $evaluationsAdded)
- ) {
- $weight = round(100 * $item->get_weight() / $main_weight, 1);
- $label = $item->get_name().' '.$weight.' % ';
- if (!empty($model)) {
- $label = $item->get_name();
- }
- $headers[] = $label;
- }
- }
- }
- $headers[] = '<span class="text-center">'.api_strtoupper(get_lang('Total')).'</span>';
- return $headers;
- }
- /**
- * @param int $id
- *
- * @return int
- */
- public function get_max_result_by_link($id)
- {
- $max = 0;
- foreach ($this->users as $user) {
- $item = $this->evals_links[$id];
- $score = $item->calc_score($user[0]);
- if ($score[0] > $max) {
- $max = $score[0];
- }
- }
- return $max;
- }
- /**
- * Get array containing evaluation items.
- *
- * @return array
- */
- public function get_evaluation_items($items_start = 0, $items_count = null)
- {
- $headers = [];
- if (!isset($items_count)) {
- $items_count = count($this->evals_links) - $items_start;
- }
- for ($count = 0; ($count < $items_count) && ($items_start + $count < count($this->evals_links)); $count++) {
- $item = $this->evals_links[$count + $items_start];
- $headers[] = $item->get_name();
- }
- return $headers;
- }
- /**
- * Get actual array data.
- *
- * @param int $users_sorting
- * @param int $users_start
- * @param null $users_count
- * @param int $items_start
- * @param null $items_count
- * @param bool $ignore_score_color
- * @param bool $show_all
- *
- * @return array 2-dimensional array - each array contains the elements:
- * 0: user id
- * 1: user lastname
- * 2: user firstname
- * 3+: evaluation/link scores
- */
- public function get_data(
- $users_sorting = 0,
- $users_start = 0,
- $users_count = null,
- $items_start = 0,
- $items_count = null,
- $ignore_score_color = false,
- $show_all = false
- ) {
- // Do some checks on users/items counts, redefine if invalid values
- if (!isset($users_count)) {
- $users_count = count($this->users) - $users_start;
- }
- if ($users_count < 0) {
- $users_count = 0;
- }
- if (!isset($items_count)) {
- $items_count = count($this->evals) + count($this->links) - $items_start;
- }
- if ($items_count < 0) {
- $items_count = 0;
- }
- $userTable = [];
- foreach ($this->users as $user) {
- $userTable[] = $user;
- }
- // sort users array
- if ($users_sorting & self::FVDG_SORT_LASTNAME) {
- usort($userTable, ['FlatViewDataGenerator', 'sort_by_last_name']);
- } elseif ($users_sorting & self::FVDG_SORT_FIRSTNAME) {
- usort($userTable, ['FlatViewDataGenerator', 'sort_by_first_name']);
- }
- if ($users_sorting & self::FVDG_SORT_DESC) {
- $userTable = array_reverse($userTable);
- }
- // Select the requested users
- $selected_users = array_slice($userTable, $users_start, $users_count);
- // Generate actual data array
- $scoreDisplay = ScoreDisplay::instance();
- $data = [];
- //@todo move these in a function
- $sum_categories_weight_array = [];
- $mainCategoryId = null;
- $mainCourseCategory = $this->getMainCourseCategory();
- if (!empty($mainCourseCategory)) {
- $mainCategoryId = $mainCourseCategory->get_id();
- }
- if (isset($this->category) && !empty($this->category)) {
- $categories = Category::load(
- null,
- null,
- null,
- $this->category->get_id()
- );
- if (!empty($categories)) {
- foreach ($categories as $category) {
- $sum_categories_weight_array[$category->get_id()] = $category->get_weight();
- }
- } else {
- $sum_categories_weight_array[$this->category->get_id()] = $this->category->get_weight();
- }
- }
- $parent_id = $this->category->get_parent_id();
- if ($parent_id == 0 ||
- (isset($this->params['only_subcat']) && $this->params['only_subcat'] == $this->category->get_id())
- ) {
- $main_weight = $this->category->get_weight();
- } else {
- $main_cat = Category::load($parent_id, null, null);
- $main_weight = $main_cat[0]->get_weight();
- }
- $export_to_pdf = false;
- if (isset($this->params['export_pdf']) && $this->params['export_pdf']) {
- $export_to_pdf = true;
- }
- $course_code = api_get_course_id();
- $session_id = api_get_session_id();
- $model = ExerciseLib::getCourseScoreModel();
- foreach ($selected_users as $user) {
- $row = [];
- // User id
- if ($export_to_pdf) {
- $row['user_id'] = $user_id = $user[0];
- } else {
- $row[] = $user_id = $user[0];
- }
- // Official code
- if (isset($this->params['show_official_code']) &&
- $this->params['show_official_code']
- ) {
- if ($export_to_pdf) {
- $row['official_code'] = $user[4];
- } else {
- $row[] = $user[4];
- }
- }
- // Last name
- if (isset($this->params['join_firstname_lastname']) &&
- $this->params['join_firstname_lastname']
- ) {
- if ($export_to_pdf) {
- $row['name'] = api_get_person_name($user[3], $user[2]);
- } else {
- $row[] = api_get_person_name($user[3], $user[2]);
- }
- } else {
- if ($export_to_pdf) {
- if (api_is_western_name_order()) {
- $row['firstname'] = $user[3];
- $row['lastname'] = $user[2];
- } else {
- $row['lastname'] = $user[2];
- $row['firstname'] = $user[3];
- }
- } else {
- if (api_is_western_name_order()) {
- $row[] = $user[3]; //first name
- $row[] = $user[2]; //last name
- } else {
- $row[] = $user[2]; //last name
- $row[] = $user[3]; //first name
- }
- }
- }
- $row[] = $user[1];
- $this->addExtraFieldColumnsData($row, $user[0]);
- $item_value_total = 0;
- $item_total = 0;
- $allcat = $this->category->get_subcategories(
- null,
- $course_code,
- $session_id,
- 'ORDER BY id'
- );
- $evaluationsAdded = [];
- if ($parent_id == 0 && !empty($allcat)) {
- /** @var Category $sub_cat */
- foreach ($allcat as $sub_cat) {
- $score = $sub_cat->calc_score($user_id);
- if (api_get_setting('gradebook_detailed_admin_view') === 'true') {
- $links = $sub_cat->get_links();
- /** @var ExerciseLink $link */
- $linkScoreList = [];
- foreach ($links as $link) {
- $linkScore = $link->calc_score($user_id);
- $linkScoreList[] = $scoreDisplay->display_score(
- $linkScore,
- SCORE_SIMPLE
- );
- }
- $evaluations = $sub_cat->get_evaluations();
- $evalScoreList = [];
- /** @var Evaluation $evaluation */
- foreach ($evaluations as $evaluation) {
- $evalScore = $evaluation->calc_score($user_id);
- $evalScoreList[] = $scoreDisplay->display_score(
- $evalScore,
- SCORE_SIMPLE
- );
- }
- }
- $real_score = $score;
- $divide = $score[1] == 0 ? 1 : $score[1];
- $sub_cat_percentage = $sum_categories_weight_array[$sub_cat->get_id()];
- $item_value = $score[0] / $divide * $main_weight;
- // Fixing total when using one or multiple gradebooks
- $percentage = $sub_cat->get_weight() / ($sub_cat_percentage) * $sub_cat_percentage / $this->category->get_weight();
- $item_value = $percentage * $item_value;
- $item_total += $sub_cat->get_weight();
- $style = api_get_configuration_value('gradebook_report_score_style');
- $defaultStyle = SCORE_DIV_SIMPLE_WITH_CUSTOM;
- if (!empty($style)) {
- $defaultStyle = (int) $style;
- }
- if (api_get_setting('gradebook_show_percentage_in_reports') === 'false') {
- $defaultShowPercentageValue = SCORE_SIMPLE;
- if (!empty($style)) {
- $defaultShowPercentageValue = $style;
- }
- $real_score = $scoreDisplay->display_score(
- $real_score,
- $defaultShowPercentageValue,
- true
- );
- $temp_score = $scoreDisplay->display_score(
- $score,
- SCORE_DIV_SIMPLE_WITH_CUSTOM,
- null
- );
- $temp_score = Display::tip($real_score, $temp_score);
- } else {
- $real_score = $scoreDisplay->display_score(
- $real_score,
- SCORE_DIV_PERCENT,
- SCORE_ONLY_SCORE
- );
- $temp_score = $scoreDisplay->display_score(
- $score,
- $defaultStyle,
- null
- );
- $temp_score = Display::tip($temp_score, $real_score);
- }
- if (!isset($this->params['only_total_category']) ||
- (isset($this->params['only_total_category']) &&
- $this->params['only_total_category'] == false)
- ) {
- if (!$show_all) {
- if (api_get_setting('gradebook_detailed_admin_view') === 'true') {
- $finalList = array_merge($linkScoreList, $evalScoreList);
- if (empty($finalList)) {
- $average = 0;
- } else {
- $average = array_sum($finalList) / count($finalList);
- }
- $finalList[] = round($average, 2);
- foreach ($finalList as $finalValue) {
- $row[] = '<span class="text-center">'.$finalValue.'</span>';
- }
- } else {
- $row[] = $temp_score.' ';
- }
- } else {
- $row[] = $temp_score;
- }
- }
- $item_value_total += $item_value;
- }
- } else {
- // All evaluations
- $result = $this->parseEvaluations(
- $user_id,
- $sum_categories_weight_array,
- $items_count,
- $items_start,
- $show_all,
- $row
- );
- $item_value_total += $result['item_value_total'];
- $evaluationsAdded = $result['evaluations_added'];
- $item_total = $main_weight;
- }
- // All evaluations
- $result = $this->parseEvaluations(
- $user_id,
- $sum_categories_weight_array,
- $items_count,
- $items_start,
- $show_all,
- $row,
- $mainCategoryId,
- $evaluationsAdded
- );
- $item_total += $result['item_total'];
- $item_value_total += $result['item_value_total'];
- $total_score = [$item_value_total, $item_total];
- $style = api_get_configuration_value('gradebook_report_score_style');
- if (!$show_all) {
- $defaultStyle = empty($style) ? SCORE_DIV_PERCENT : (int) $style;
- $displayScore = $scoreDisplay->display_score($total_score, $defaultStyle);
- if (!empty($model)) {
- $displayScore = ExerciseLib::show_score($total_score[0], $total_score[1]);
- }
- if ($export_to_pdf) {
- $row['total'] = $displayScore;
- } else {
- $row[] = $displayScore;
- }
- } else {
- $defaultStyle = empty($style) ? SCORE_DIV_SIMPLE_WITH_CUSTOM_LETTERS : (int) $style;
- $displayScore = $scoreDisplay->display_score($total_score, $defaultStyle);
- if (!empty($model)) {
- $displayScore = ExerciseLib::show_score($total_score[0], $total_score[1]);
- }
- if ($export_to_pdf) {
- $row['total'] = $displayScore;
- } else {
- $row[] = $displayScore;
- }
- }
- unset($score);
- $data[] = $row;
- }
- return $data;
- }
- /**
- * Parse evaluations.
- *
- * @param int $user_id
- * @param array $sum_categories_weight_array
- * @param int $items_count
- * @param int $items_start
- * @param int $show_all
- * @param int $parentCategoryIdFilter filter by category id if set
- *
- * @return array
- */
- public function parseEvaluations(
- $user_id,
- $sum_categories_weight_array,
- $items_count,
- $items_start,
- $show_all,
- &$row,
- $parentCategoryIdFilter = null,
- $evaluationsAlreadyAdded = []
- ) {
- // Generate actual data array
- $scoreDisplay = ScoreDisplay::instance();
- $item_total = 0;
- $item_value_total = 0;
- $evaluationsAdded = [];
- $model = ExerciseLib::getCourseScoreModel();
- for ($count = 0; $count < $items_count && ($items_start + $count < count($this->evals_links)); $count++) {
- /** @var AbstractLink $item */
- $item = $this->evals_links[$count + $items_start];
- if (!empty($evaluationsAlreadyAdded)) {
- if (in_array($item->get_id(), $evaluationsAlreadyAdded)) {
- continue;
- }
- }
- if (!empty($parentCategoryIdFilter)) {
- if ($item->get_category_id() != $parentCategoryIdFilter) {
- continue;
- }
- }
- $evaluationsAdded[] = $item->get_id();
- $score = $item->calc_score($user_id);
- $real_score = $score;
- $divide = isset($score[1]) && !empty($score[1]) && $score[1] > 0 ? $score[1] : 1;
- // Sub cat weight
- $item_value = isset($score[0]) ? $score[0] / $divide : 0;
- // Fixing total when using one or multiple gradebooks.
- if (empty($parentCategoryIdFilter)) {
- if ($this->category->get_parent_id() == 0) {
- if (isset($score[0])) {
- $item_value = $score[0] / $divide * $item->get_weight();
- } else {
- $item_value = 0;
- }
- } else {
- $item_value = $item_value * $item->get_weight();
- }
- } else {
- $item_value = $score[0] / $divide * $item->get_weight();
- }
- $item_total += $item->get_weight();
- $style = api_get_configuration_value('gradebook_report_score_style');
- $defaultStyle = SCORE_DIV_SIMPLE_WITH_CUSTOM;
- if (!empty($style)) {
- $defaultStyle = (int) $style;
- }
- $complete_score = $scoreDisplay->display_score(
- $score,
- SCORE_DIV_PERCENT,
- SCORE_ONLY_SCORE
- );
- if (api_get_setting('gradebook_show_percentage_in_reports') == 'false') {
- $defaultShowPercentageValue = SCORE_SIMPLE;
- if (!empty($style)) {
- $defaultShowPercentageValue = $style;
- }
- $real_score = $scoreDisplay->display_score(
- $real_score,
- $defaultShowPercentageValue
- );
- $temp_score = $scoreDisplay->display_score(
- [$item_value, null],
- SCORE_DIV_SIMPLE_WITH_CUSTOM
- );
- $temp_score = Display::tip($real_score, $temp_score);
- } else {
- $temp_score = $scoreDisplay->display_score(
- $real_score,
- $defaultStyle
- );
- $temp_score = Display::tip($temp_score, $complete_score);
- }
- if (!empty($model)) {
- $scoreToShow = '';
- if (isset($score[0]) && isset($score[1])) {
- $scoreToShow = ExerciseLib::show_score($score[0], $score[1]);
- }
- $temp_score = $scoreToShow;
- }
- if (!isset($this->params['only_total_category']) ||
- (isset($this->params['only_total_category']) && $this->params['only_total_category'] == false)
- ) {
- if (!$show_all) {
- if (in_array(
- $item->get_type(),
- [
- LINK_EXERCISE,
- LINK_DROPBOX,
- LINK_STUDENTPUBLICATION,
- LINK_LEARNPATH,
- LINK_FORUM_THREAD,
- LINK_ATTENDANCE,
- LINK_SURVEY,
- LINK_HOTPOTATOES,
- ]
- )
- ) {
- if (!empty($score[0])) {
- $row[] = $temp_score.' ';
- } else {
- $row[] = '';
- }
- } else {
- $row[] = $temp_score.' ';
- }
- } else {
- $row[] = $temp_score;
- }
- }
- $item_value_total += $item_value;
- }
- return [
- 'item_total' => $item_total,
- 'item_value_total' => $item_value_total,
- 'evaluations_added' => $evaluationsAdded,
- ];
- }
- /**
- * Get actual array data evaluation/link scores.
- *
- * @param int $session_id
- *
- * @return array
- */
- public function getEvaluationSummaryResults($session_id = null)
- {
- $usertable = [];
- foreach ($this->users as $user) {
- $usertable[] = $user;
- }
- $selected_users = $usertable;
- // generate actual data array for all selected users
- $data = [];
- foreach ($selected_users as $user) {
- $row = [];
- for ($count = 0; $count < count($this->evals_links); $count++) {
- $item = $this->evals_links[$count];
- $score = $item->calc_score($user[0]);
- $porcent_score = isset($score[1]) && $score[1] > 0 ? ($score[0] * 100) / $score[1] : 0;
- $row[$item->get_name()] = $porcent_score;
- }
- $data[$user[0]] = $row;
- }
- // get evaluations for every user by item
- $data_by_item = [];
- foreach ($data as $uid => $items) {
- $tmp = [];
- foreach ($items as $item => $value) {
- $tmp[] = $item;
- if (in_array($item, $tmp)) {
- $data_by_item[$item][$uid] = $value;
- }
- }
- }
- /* Get evaluation summary results
- (maximum, minimum and average of evaluations for all students)
- */
- $result = [];
- foreach ($data_by_item as $k => $v) {
- $average = round(array_sum($v) / count($v));
- arsort($v);
- $maximum = array_shift($v);
- $minimum = array_pop($v);
- if (is_null($minimum)) {
- $minimum = 0;
- }
- $summary = [
- 'max' => $maximum,
- 'min' => $minimum,
- 'avg' => $average,
- ];
- $result[$k] = $summary;
- }
- return $result;
- }
- /**
- * @return array
- */
- public function get_data_to_graph()
- {
- // do some checks on users/items counts, redefine if invalid values
- $usertable = [];
- foreach ($this->users as $user) {
- $usertable[] = $user;
- }
- // sort users array
- usort($usertable, ['FlatViewDataGenerator', 'sort_by_first_name']);
- $data = [];
- $selected_users = $usertable;
- foreach ($selected_users as $user) {
- $row = [];
- $row[] = $user[0]; // user id
- $item_value = 0;
- $item_total = 0;
- for ($count = 0; $count < count($this->evals_links); $count++) {
- $item = $this->evals_links[$count];
- $score = $item->calc_score($user[0]);
- $divide = (($score[1]) == 0) ? 1 : $score[1];
- $item_value += $score[0] / $divide * $item->get_weight();
- $item_total += $item->get_weight();
- $score_denom = ($score[1] == 0) ? 1 : $score[1];
- $score_final = ($score[0] / $score_denom) * 100;
- $row[] = $score_final;
- }
- $score_final = ($item_value / $item_total) * 100;
- $row[] = $score_final;
- $data[] = $row;
- }
- return $data;
- }
- /**
- * This is a function to show the generated data.
- *
- * @param bool $displayWarning
- *
- * @return array
- */
- public function get_data_to_graph2($displayWarning = true)
- {
- $course_code = api_get_course_id();
- $session_id = api_get_session_id();
- // do some checks on users/items counts, redefine if invalid values
- $usertable = [];
- foreach ($this->users as $user) {
- $usertable[] = $user;
- }
- // sort users array
- usort($usertable, ['FlatViewDataGenerator', 'sort_by_first_name']);
- // generate actual data array
- $scoreDisplay = ScoreDisplay::instance();
- $data = [];
- $selected_users = $usertable;
- foreach ($selected_users as $user) {
- $row = [];
- $row[] = $user[0]; // user id
- $item_value = 0;
- $item_total = 0;
- $final_score = 0;
- $item_value_total = 0;
- $allcat = $this->category->get_subcategories(
- null,
- $course_code,
- $session_id,
- 'ORDER BY id'
- );
- $parent_id = $this->category->get_parent_id();
- if ($parent_id == 0 && !empty($allcat)) {
- foreach ($allcat as $sub_cat) {
- $score = $sub_cat->calc_score($user[0]);
- $real_score = $score;
- $main_weight = $this->category->get_weight();
- $divide = $score[1] == 0 ? 1 : $score[1];
- //$sub_cat_percentage = $sum_categories_weight_array[$sub_cat->get_id()];
- $item_value = $score[0] / $divide * $main_weight;
- $item_total += $sub_cat->get_weight();
- $row[] = [
- $item_value,
- trim(
- $scoreDisplay->display_score(
- $real_score,
- SCORE_CUSTOM,
- null,
- true
- )
- ),
- ];
- $item_value_total += $item_value;
- $final_score += $score[0];
- //$final_score = ($final_score / $item_total) * 100;
- }
- $total_score = [$final_score, $item_total];
- $row[] = [
- $final_score,
- trim(
- $scoreDisplay->display_score(
- $total_score,
- SCORE_CUSTOM,
- null,
- true
- )
- ),
- ];
- } else {
- for ($count = 0; $count < count($this->evals_links); $count++) {
- $item = $this->evals_links[$count];
- $score = $item->calc_score($user[0]);
- $divide = $score[1] == 0 ? 1 : $score[1];
- $item_value += $score[0] / $divide * $item->get_weight();
- $item_total += $item->get_weight();
- $score_denom = ($score[1] == 0) ? 1 : $score[1];
- $score_final = ($score[0] / $score_denom) * 100;
- $row[] = [
- $score_final,
- trim(
- $scoreDisplay->display_score(
- $score,
- SCORE_CUSTOM,
- null,
- true
- )
- ),
- ];
- }
- $total_score = [$item_value, $item_total];
- $score_final = ($item_value / $item_total) * 100;
- if ($displayWarning) {
- echo Display::return_message($total_score[1], 'warning');
- }
- $row[] = [
- $score_final,
- trim(
- $scoreDisplay->display_score(
- $total_score,
- SCORE_CUSTOM,
- null,
- true
- )
- ),
- ];
- }
- $data[] = $row;
- }
- return $data;
- }
- /**
- * @param $item1
- * @param $item2
- *
- * @return int
- */
- public function sort_by_last_name($item1, $item2)
- {
- return api_strcmp($item1[2], $item2[2]);
- }
- /**
- * @param $item1
- * @param $item2
- *
- * @return int
- */
- public function sort_by_first_name($item1, $item2)
- {
- return api_strcmp($item1[3], $item2[3]);
- }
- /**
- * Add columns heders according to gradebook_flatview_extrafields_columns conf setting.
- *
- * @param array $headers
- */
- private function addExtraFieldColumnsHeaders(array &$headers)
- {
- $extraFieldColumns = api_get_configuration_value('gradebook_flatview_extrafields_columns');
- if (!$extraFieldColumns || !is_array($extraFieldColumns)) {
- return;
- }
- foreach ($extraFieldColumns['variables'] as $extraFieldVariable) {
- $extraField = new ExtraField('user');
- $extraFieldInfo = $extraField->get_handler_field_info_by_field_variable($extraFieldVariable);
- $headers[] = $extraFieldInfo['display_text'];
- }
- }
- /**
- * Add columns data according to gradebook_flatview_extrafields_columns conf setting.
- *
- * @param array $row
- * @param int $userId
- */
- private function addExtraFieldColumnsData(array &$row, $userId)
- {
- $extraFieldColumns = api_get_configuration_value('gradebook_flatview_extrafields_columns');
- if (!$extraFieldColumns || !is_array($extraFieldColumns)) {
- return;
- }
- foreach ($extraFieldColumns['variables'] as $extraFieldVariable) {
- $extraFieldValue = new ExtraFieldValue('user');
- $extraFieldValueInfo = $extraFieldValue->get_values_by_handler_and_field_variable(
- $userId,
- $extraFieldVariable
- );
- $row[] = $extraFieldValueInfo ? $extraFieldValueInfo['value'] : null;
- }
- }
- }
|