mirror of
https://github.com/moodle/moodle.git
synced 2025-08-05 00:46:50 +02:00
MDL-10579 Implement capability checks in grade import/export/report/edit pages - work in progress
refactoring - reports now use real index.php
This commit is contained in:
parent
7229af7890
commit
65dd61bda6
12 changed files with 332 additions and 348 deletions
146
grade/index.php
146
grade/index.php
|
@ -1,142 +1,12 @@
|
|||
<?PHP
|
||||
require_once("../config.php");
|
||||
require_once("lib.php");
|
||||
<?php //$Id$
|
||||
|
||||
$id = required_param('id'); // course id
|
||||
$download = optional_param('download');
|
||||
$user = optional_param('user', -1);
|
||||
$action = optional_param('action', 'grades');
|
||||
$cview = optional_param('cview', -1);
|
||||
/*
|
||||
* Compatibility redirection to reports
|
||||
*/
|
||||
|
||||
if (!$course = get_record('course', 'id', $id)) {
|
||||
error('No course ID');
|
||||
}
|
||||
require '../config.php';
|
||||
|
||||
require_login($course->id);
|
||||
$id = required_param('id', PARAM_INT);
|
||||
redirect('report/index.php?id='.$id);
|
||||
|
||||
// if the user set new prefs make sure they happen now
|
||||
if ($action == 'set_grade_preferences' && $prefs = data_submitted()) {
|
||||
if (!confirm_sesskey()) {
|
||||
error(get_string('confirmsesskeybad', 'error'));
|
||||
}
|
||||
grade_set_preferences($course, $prefs);
|
||||
}
|
||||
|
||||
$preferences = grade_get_preferences($course->id);
|
||||
|
||||
|
||||
// we want this in its own window
|
||||
if ($action == 'stats') {
|
||||
grade_stats();
|
||||
exit();
|
||||
} else if ($action == 'ods') {
|
||||
grade_download('ods', $id);
|
||||
exit();
|
||||
} else if ($action == 'excel') {
|
||||
grade_download('xls', $id);
|
||||
exit();
|
||||
} else if ($action == 'text') {
|
||||
grade_download('txt', $id);
|
||||
exit();
|
||||
}
|
||||
|
||||
print_header($course->shortname.': '.get_string('grades'), $course->fullname, grade_nav($course, $action));
|
||||
|
||||
print_heading('This old gradebook may not work properly. See the <a href="report.php?id='.$course->id.'">new 1.9 gradebook</a>');
|
||||
|
||||
/// find out current groups mode
|
||||
$groupmode = groupmode($course);
|
||||
$currentgroup = setup_and_print_groups($course, $groupmode, 'index.php?id=' . $course->id);
|
||||
echo '<div class="clearer"></div>';
|
||||
|
||||
grade_preferences_menu($action, $course);
|
||||
|
||||
grade_set_uncategorized();
|
||||
|
||||
if (has_capability('moodle/course:viewcoursegrades', get_context_instance(CONTEXT_COURSE, $course->id))) {
|
||||
switch ($action) {
|
||||
case "cats":
|
||||
grade_set_categories();
|
||||
break;
|
||||
case "insert_category":
|
||||
grade_insert_category();
|
||||
grade_set_categories();
|
||||
break;
|
||||
case "assign_categories":
|
||||
grade_assign_categories();
|
||||
grade_set_categories();
|
||||
break;
|
||||
case "set_grade_weights":
|
||||
grade_set_grade_weights();
|
||||
grade_display_grade_weights();
|
||||
break;
|
||||
case "weights":
|
||||
grade_display_grade_weights();
|
||||
break;
|
||||
case "grades":
|
||||
if ($preferences->use_advanced == 1) {
|
||||
grade_view_all_grades($user);
|
||||
}
|
||||
else {
|
||||
// all the grades will be in the 'uncategorized' category
|
||||
grade_view_category_grades($user);
|
||||
}
|
||||
break;
|
||||
case "vcats":
|
||||
grade_view_category_grades($user);
|
||||
break;
|
||||
case "prefs":
|
||||
case "set_grade_preferences":
|
||||
grade_display_grade_preferences($course, $preferences);
|
||||
break;
|
||||
case "letters":
|
||||
grade_display_letter_grades();
|
||||
break;
|
||||
case "set_letter_grades":
|
||||
grade_set_letter_grades();
|
||||
grade_display_letter_grades();
|
||||
break;
|
||||
case "delete_category":
|
||||
grade_delete_category();
|
||||
// re-run set_uncategorized as they may have deleted a category that had items in it
|
||||
grade_set_uncategorized();
|
||||
grade_set_categories();
|
||||
break;
|
||||
case "view_student_grades":
|
||||
grade_view_all_grades($user);
|
||||
break;
|
||||
case "view_student_category_grades":
|
||||
grade_view_category_grades($user);
|
||||
break;
|
||||
default:
|
||||
if ($preferences->use_advanced == 1) {
|
||||
grade_view_all_grades($user);
|
||||
}
|
||||
else {
|
||||
grade_view_category_grades($user);
|
||||
}
|
||||
} // end switch
|
||||
} // end if isTeacher
|
||||
else {
|
||||
if ($preferences->show_weighted || $preferences->show_points || $preferences->show_percent) {
|
||||
|
||||
if ($preferences->use_advanced == 1) {
|
||||
if($action != 'vcats') {
|
||||
grade_view_all_grades($USER->id);
|
||||
}
|
||||
else {
|
||||
grade_view_category_grades($USER->id);
|
||||
}
|
||||
} else {
|
||||
grade_view_category_grades($USER->id);
|
||||
}
|
||||
|
||||
} else {
|
||||
error(get_string('gradebookhiddenerror','grades'));
|
||||
}
|
||||
} // end else (!teacher)
|
||||
|
||||
print_footer($course);
|
||||
|
||||
|
||||
?>
|
||||
?>
|
Loading…
Add table
Add a link
Reference in a new issue