|
|
|
|
@ -55,7 +55,17 @@ class GradebookTable extends SortableTable |
|
|
|
|
$this->set_header($column++, get_lang('Type')); |
|
|
|
|
$this->set_header($column++, get_lang('Name')); |
|
|
|
|
$this->set_header($column++, get_lang('Description')); |
|
|
|
|
if (api_is_allowed_to_create_course()) { |
|
|
|
|
$this->set_header($column++, get_lang('Weight')); |
|
|
|
|
} else { |
|
|
|
|
if (!isset($_GET['selectcat'])) { |
|
|
|
|
$this->set_header($column++, get_lang('Evaluation')); |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
$this->set_header($column++, get_lang('Weight')); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
$this->set_header($column++, get_lang('Date'),true, 'width="100"'); |
|
|
|
|
|
|
|
|
|
//admins get an edit column |
|
|
|
|
@ -71,7 +81,9 @@ class GradebookTable extends SortableTable |
|
|
|
|
if(count($evals_links)>0) { |
|
|
|
|
$this->set_header($column++, get_lang('Results'), false); |
|
|
|
|
} |
|
|
|
|
//$this->set_header($column++, get_lang('Certificates'), false); |
|
|
|
|
if (!isset($_GET['selectcat'])) { |
|
|
|
|
$this->set_header($column++, get_lang('Certificates'),false); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@ -121,7 +133,9 @@ class GradebookTable extends SortableTable |
|
|
|
|
$row = array (); |
|
|
|
|
|
|
|
|
|
$item = $data[0]; |
|
|
|
|
|
|
|
|
|
if (!isset($_GET['selectcat'])) { |
|
|
|
|
$certificate_min_score = $this->build_cetificate_min_score($item); |
|
|
|
|
} |
|
|
|
|
//if the item is invisible, wrap it in a span with class invisible |
|
|
|
|
$invisibility_span_open = (api_is_allowed_to_create_course() && $item->is_visible() == '0') ? '<span class="invisible">' : ''; |
|
|
|
|
$invisibility_span_close = (api_is_allowed_to_create_course() && $item->is_visible() == '0') ? '</span>' : ''; |
|
|
|
|
@ -133,7 +147,36 @@ class GradebookTable extends SortableTable |
|
|
|
|
$row[] = $this->build_type_column ($item); |
|
|
|
|
$row[] = $invisibility_span_open . $this->build_name_link ($item) . $invisibility_span_close; |
|
|
|
|
$row[] = $invisibility_span_open . $data[2] . $invisibility_span_close; |
|
|
|
|
|
|
|
|
|
if (api_is_allowed_to_create_course()) { |
|
|
|
|
$row[] = $invisibility_span_open . $data[3] . $invisibility_span_close; |
|
|
|
|
} else { |
|
|
|
|
|
|
|
|
|
if (!isset($_GET['selectcat'])) { |
|
|
|
|
// generating the total score for a course |
|
|
|
|
$stud_id= api_get_user_id(); |
|
|
|
|
|
|
|
|
|
$cats_course = Category :: load (0, null, null, null, null, null, false); |
|
|
|
|
$alleval_course= $cats_course[0]->get_evaluations($stud_id,true); |
|
|
|
|
$alllink_course= $cats_course[0]->get_links($stud_id,true); |
|
|
|
|
$evals_links = array_merge($alleval_course, $alllink_course); |
|
|
|
|
$item_value=0; |
|
|
|
|
$item_total=0; |
|
|
|
|
for ($count=0; $count < count($evals_links); $count++) { |
|
|
|
|
$item = $evals_links[$count]; |
|
|
|
|
$score = $item->calc_score($stud_id); |
|
|
|
|
$item_value+=$score[0]/$score[1]*$item->get_weight(); |
|
|
|
|
$item_total+=$item->get_weight(); |
|
|
|
|
} |
|
|
|
|
$item_value = number_format($item_value, 2, '.', ' '); |
|
|
|
|
$cattotal = Category :: load(0); |
|
|
|
|
$scoretotal= $cattotal[0]->calc_score(api_get_user_id()); |
|
|
|
|
$scoretotal_display = (isset($scoretotal) ? $scoretotal[0].'/'.$scoretotal[1].'('.round(($scoretotal[0] / $scoretotal[1]) * 100) . ' %)': get_lang('NoResultsAvailable')); |
|
|
|
|
$row[] = $item_value; |
|
|
|
|
} else { |
|
|
|
|
$row[] = $invisibility_span_open . $data[3] . $invisibility_span_close; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
$row[] = $invisibility_span_open . str_replace(' ',' ',$data[4]) . $invisibility_span_close; |
|
|
|
|
|
|
|
|
|
//admins get an edit column |
|
|
|
|
@ -144,7 +187,14 @@ class GradebookTable extends SortableTable |
|
|
|
|
if (count($this->evals_links)>0) { |
|
|
|
|
$row[] = $data[5]; |
|
|
|
|
} |
|
|
|
|
//$row[] = $data[6]; |
|
|
|
|
if (!isset($_GET['selectcat'])) { |
|
|
|
|
if ((int)$item_value >= (int)$certificate_min_score) { |
|
|
|
|
$certificates = '<a href="'.api_get_path(WEB_CODE_PATH) .'gradebook/index.php?export_certificate=yes"><img src="'.api_get_path(WEB_CODE_PATH) . 'img/dokeos.gif" /></a> '.$scoretotal_display; |
|
|
|
|
} else { |
|
|
|
|
$certificates = get_lang('NoResultsAvailable'); |
|
|
|
|
} |
|
|
|
|
$row[] = $certificates; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
$sortable_data[] = $row; |
|
|
|
|
} |
|
|
|
|
@ -153,6 +203,11 @@ class GradebookTable extends SortableTable |
|
|
|
|
} |
|
|
|
|
// Other functions |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private function build_cetificate_min_score ($item) { |
|
|
|
|
return $item->get_certificate_min_score(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
private function build_id_column ($item) { |
|
|
|
|
switch ($item->get_item_type()) { |
|
|
|
|
// category |
|
|
|
|
|