include_once($CFG->libdir.'/pear/HTML/QuickForm/advcheckbox.php');
$mform =& $this->_form;
$mform->addElement('header', 'general', get_string('gradeitemsinc', 'grades')); // TODO: localize
+
+ $mform->addElement('checkbox', 'export_letters', get_string('exportletters', 'grades'));
+ $mform->setDefault('export_letters', 0);
+ $mform->setHelpButton('export_letters', array(false, get_string('exportletters', 'grades'),
+ false, true, false, get_string("exportlettershelp", 'grades')));
+
$id = $this->_customdata['id']; // course id
$mform->addElement('hidden', 'id', $id);
if ($grade_items = grade_item::fetch_all(array('courseid'=>$id))) {
$this->add_action_buttons(false, get_string('submit'));
}
}
-?>
\ No newline at end of file
+?>
require_once($CFG->dirroot.'/lib/gradelib.php');
require_once($CFG->dirroot.'/grade/lib.php');
+
/**
* Prints all grade items for selection
* @input int id - course id
/**
* Constructor should set up all the private variables ready to be pulled
- * @input int id - course id
- * @input string itemids - comma separated value of itemids to process for this export
+ * @param int $id course id
+ * @param string $itemids comma separated value of itemids to process for this export
+ * @param boolean $export_letters Whether to export letter grade_items as literal letters, or as numerical values
+ * @note Exporting as letters will lead to data loss if that exported set it re-imported.
*/
- function grade_export($id, $itemids = '') {
+ function grade_export($id, $itemids = '', $export_letters=false) {
+
+ if ($export_letters) {
+ require_once($CFG->dirroot . '/grade/report/lib.php');
+ $report = new grade_report();
+ $letters = $report->get_grade_letters();
+ }
$this->strgrades = get_string("grades");
$this->strgrade = get_string("grade");
}
} else {
// else we get all items for this course
- $gradeitems = grade_grade::fetch_all(array('courseid'=>$this->id));
+ $gradeitems = grade_item::fetch_all(array('courseid'=>$this->id));
}
if ($gradeitems) {
foreach ($gradeitems as $gradeitem) {
+ $grade_item_displaytype = $report->get_pref('gradedisplaytype', $gradeitem->id);
// load as an array of grade_final objects
- if ($itemgrades = $gradeitem -> get_final()) {
+ if ($itemgrades = $gradeitem->get_final()) {
$this->columns[$gradeitem->id] = "$gradeitem->itemmodule: ".$gradeitem->get_name()." - $gradeitem->grademax";
if (!empty($this->students)) {
foreach ($this->students as $student) {
unset($studentgrade);
- // add support for comment here MDL-9634
+ // TODO add support for comment here MDL-9634
if (!empty($itemgrades[$student->id])) {
$studentgrade = $itemgrades[$student->id];
}
+ // TODO Convert final grade to letter if export option is on, and grade_item is set to letter type MDL-10490
+ if ($grade_item_displaytype == GRADE_REPORT_GRADE_DISPLAY_TYPE_LETTER && $export_letters) {
+ $studentgrade->finalgrade = $studentgrade->get_letter($letters);
+ }
+
if (!empty($studentgrade->finalgrade)) {
$this->grades[$student->id][$gradeitem->id] = $currentstudentgrade = $studentgrade->finalgrade;
} else {
$this->gradeshtml[$student->id][$gradeitem->id] = "";
}
if (!empty($maxgrade)) {
- $this->totals[$student->id] = (float)($this->totals[$student->id]) + (float)($currentstudentgrade);
+ $total = (float)($this->totals[$student->id]) + (float)($currentstudentgrade);
} else {
- $this->totals[$student->id] = (float)($this->totals[$student->id]) + 0;
+ $total = (float)($this->totals[$student->id]) + 0;
+ }
+
+ if ($export_letters) {
+ $total = grade_grade::get_letter($letters, $total, $gradeitem->grademin, $gradeitem->grademax);
}
+ $this->totals[$student->id] = $total;
if (!empty($comment)) {
// load comments here
}
/**
- * To be implemented by child classes
+ * To be implemented by child classe
+ * TODO finish PHPdocs
*/
function print_grades() { }
/**
* Displays all the grades on screen as a feedback mechanism
+ * TODO finish PHPdoc
*/
function display_grades($feedback=false) {
echo '<table>';
// print the grades on screen for feedbacks
- $export = new grade_export($id, $data->itemids);
+ $export = new grade_export($id, $data->itemids, $data->export_letters);
$export->display_grades($feedback);
// this redirect should trigger a download prompt
$itemidsurl = implode(",",$data->itemids);
}
- $export = new grade_export($id, $data->itemids);
+ $export = new grade_export($id, $data->itemids, $data->export_letters);
$export->display_grades($feedback);
// this redirect should trigger a download prompt
// print the grades on screen for feedbacks
- $export = new grade_export($id, $data->itemids);
+ $export = new grade_export($id, $data->itemids, $data->export_letters);
$export->display_grades($feedback);
// this redirect should trigger a download prompt
// print the grades on screen for feedbacks
- $export = new grade_export($id, $data->itemids);
+ $export = new grade_export($id, $data->itemids, $data->export_letters);
$export->display_grades($feedback);
// this redirect should trigger a download prompt
if ($grades = get_records('grade_import_values', 'newgradeitem', $newitem->id)) {
- // make the grardes array for update_grade
+ // make the grades array for update_grade
// find the max instance number of 'manual' grade item
// and increment that number by 1 by hand
}
$instances[] = $instance;
+
+ // TODO clean up following comment?
// if fails, deletes all the created grade_items and grades
/// create a new grade item for this
if ($failed) {
foreach ($instances as $instance) {
$gradeitem = new grade_item(array('courseid'=>$courseid, 'itemtype'=>'manual', 'iteminstance'=>$instance));
- // this method does not seem to delete all the raw grades and the item itself
+ // TODO this method does not seem to delete all the raw grades and the item itself
// which I think should be deleted in this case, can I use sql directly here?
$gradeitem->delete();
}
// get all grades with this item
if ($grades = get_records('grade_import_values', 'itemid', $itemid)) {
- // make the grardes array for update_grade
+ // make the grades array for update_grade
foreach ($grades as $grade) {
if (!$gradeitem->update_final_grade($grade->userid, $grade->finalgrade, NULL, NULL, $grade->feedback)) {
$failed = 1;
}
return $data;
}
-?>
\ No newline at end of file
+?>