]> git.mjollnir.org Git - moodle.git/commitdiff
improced assigning of used course outcomes, added return tracking to scale links...
authorskodak <skodak>
Tue, 31 Jul 2007 10:57:05 +0000 (10:57 +0000)
committerskodak <skodak>
Tue, 31 Jul 2007 10:57:05 +0000 (10:57 +0000)
grade/edit/outcome/course.php
grade/edit/outcome/course_form.html
grade/edit/outcome/index.php
lang/en_utf8/grades.php

index 0aae40c463480fc6c31f8d9f661051583060d754..aa1dd58ea4bb838557ef1f87ea7bcd43b23f5bc7 100644 (file)
@@ -15,27 +15,101 @@ require_login($course);
 $context = get_context_instance(CONTEXT_COURSE, $course->id);
 require_capability('moodle/course:update', $context);
 
+/// return tracking object
+$gpr = new grade_plugin_return(array('type'=>'edit', 'plugin'=>'outcomes', 'courseid'=>$courseid));
+
+// first of all fix the state of outcomes_course table
+if (!$standardoutcomes = grade_outcome::fetch_all_global()) {
+    $standardoutcomes = array();
+}
+if (!$co_custom = grade_outcome::fetch_all_local($courseid)) {
+    $co_custom = array();
+}
+$co_standard_used = array();
+$co_standard_notused = array();
+
+if ($courseused = get_records('grade_outcomes_courses', 'courseid', $courseid, '', 'outcomeid')) {
+    $courseused = array_keys($courseused);
+} else {
+    $courseused = array();
+}
+
+// fix wrong entries in outcomes_courses
+foreach ($courseused as $oid) {
+    if (!array_key_exists($oid, $standardoutcomes) and !array_key_exists($oid, $co_custom)) {
+        delete_records('grade_outcomes_courses', 'outcomeid', $oid, 'courseid', $courseid);
+    }
+}
+
+// fix local custom outcomes missing in outcomes_course
+foreach($co_custom as $oid=>$outcome) {
+    if (!in_array($oid, $courseused)) {
+        $courseused[$oid] = $oid;
+        $obj = new object();
+        $obj->courseid = $courseid;
+        $obj->outcomeid = $oid;
+        insert_record('grade_outcomes_courses', $obj);
+    }
+}
+
+// now check all used standard outcomes are in outcomes_course too
+if ($realused = get_records_select('grade_items', "courseid=$courseid and outcomeid IS NOT NULL", '', 'outcomeid')) {
+    $realused = array_keys($realused);
+    foreach ($realused as $oid) {
+        if (array_key_exists($oid, $standardoutcomes)) {
+
+            $co_standard_used[$oid] = $standardoutcomes[$oid];
+            unset($standardoutcomes[$oid]);
+
+            if (!in_array($oid, $courseused)) {
+                $courseused[$oid] = $oid;
+                $obj = new object();
+                $obj->courseid = $courseid;
+                $obj->outcomeid = $oid;
+                insert_record('grade_outcomes_courses', $obj);
+            }
+        }
+    }
+}
+
+// find all unused standard course outcomes - candidates for removal
+foreach ($standardoutcomes as $oid=>$outcome) {
+    if (in_array($oid, $courseused)) {
+        $co_standard_notused[$oid] = $standardoutcomes[$oid];
+        unset($standardoutcomes[$oid]);
+    }
+}
+
+
 /// form processing
 if ($data = data_submitted()) {
-    require_capability('moodle/grade:manageoutcomes', get_context_instance(CONTEXT_COURSE, $courseid));
+    require_capability('moodle/grade:manageoutcomes', $context);
     if (!empty($data->add) && !empty($data->addoutcomes)) {
     /// add all selected to course list
         foreach ($data->addoutcomes as $add) {
-            $goc -> courseid = $courseid;
-            $goc -> outcomeid = $add;
+            $add = clean_param($add, PARAM_INT);
+            if (!array_key_exists($add, $standardoutcomes)) {
+                continue;
+            }
+            $goc = new object();
+            $goc->courseid = $courseid;
+            $goc->outcomeid = $add;
             insert_record('grade_outcomes_courses', $goc);
         }
+
     } else if (!empty($data->remove) && !empty($data->removeoutcomes)) {
     /// remove all selected from course outcomes list
         foreach ($data->removeoutcomes as $remove) {
+            $remove = clean_param($remove, PARAM_INT);
+            if (!array_key_exists($remove, $co_standard_notused)) {
+                continue;
+            }
             delete_records('grade_outcomes_courses', 'courseid', $courseid, 'outcomeid', $remove);
         }
     }
+    redirect('course.php?id='.$courseid); // we must redirect to get fresh data
 }
 
-/// return tracking object
-$gpr = new grade_plugin_return(array('type'=>'edit', 'plugin'=>'outcomes', 'courseid'=>$courseid));
-
 $strgrades = get_string('grades');
 $pagename  = get_string('outcomescourse', 'grades');
 
@@ -43,23 +117,6 @@ $navlinks = array(array('name'=>$strgrades, 'link'=>$CFG->wwwroot.'/grade/index.
                   array('name'=>$pagename, 'link'=>'', 'type'=>'misc'));
 $navigation = build_navigation($navlinks);
 
-$outcomes = grade_outcome::fetch_all_global();
-$courseoutcomes = array();
-if ($coutcomes = get_records_sql('SELECT go.id, go.fullname
-                                       FROM '.$CFG->prefix.'grade_outcomes_courses goc,
-                                            '.$CFG->prefix.'grade_outcomes go
-                                        WHERE goc.courseid = '.$courseid.'
-                                       AND goc.outcomeid = go.id')) {
-    foreach ($coutcomes as $id=>$coutcome) {
-        $courseoutcomes[$id] = new grade_outcome(array('id'=>$id));
-    }
-}
-
-if (empty($courseoutcomes)) {
-    $courseoutcomes = grade_outcome::fetch_all(array('courseid'=>$courseid));
-} elseif ($mcourseoutcomes = grade_outcome::fetch_all(array('courseid'=>$courseid))) {
-    $courseoutcomes += $mcourseoutcomes;
-}
 /// Print header
 print_header_simple($strgrades.': '.$pagename, ': '.$strgrades, $navigation, '', '', true, '', navmenu($course));
 
index 002a00d94ef20b53bf625b8ce47596ea5addf88d..15d98bb2f17735300a239c7bf227b8c92746202a 100755 (executable)
@@ -1,22 +1,22 @@
-<form action="index.php" method="post">
+<form action="course.php" method="post">
 <div>
 <table style="margin-left:auto;margin-right:auto">
     <tr>
         <td>
-            <label for="addoutcomes"><?php print_string('outcomesstandard', 'grades'); ?></label>
+            <label for="addoutcomes"><?php print_string('outcomesstandardavailable', 'grades'); ?></label>
             <br />
             <select id="addoutcomes" size="20" name="addoutcomes[]" multiple="multiple">
 
             <?php
-            foreach ($outcomes as $outcome) {
-                if (in_array($outcome->id, array_keys($courseoutcomes))) {
-                    continue;
-                }
+            foreach ($standardoutcomes as $outcome) {
                 echo '<option value="'.$outcome->id.'">'.$outcome->get_name().'</option>';
             }
             ?>
             </select>
         </td>
+        <?php
+        if (has_capability('moodle/grade:manageoutcomes', $context)) {
+        ?>
         <td>
             <p class="arrow_button">
                 <input name="add" id="add" type="submit" value="<?php echo '&nbsp; '.$THEME->rarrow.' &nbsp; &nbsp; '.get_string('add'); ?>" title="<?php print_string('add'); ?>" />
                 <input name="remove" id="remove" type="submit" value="<?php echo '&nbsp;'.$THEME->larrow.' &nbsp; &nbsp; '.get_string('remove'); ?>" title="<?php print_string('remove'); ?>" />
             </p>
         </td>
+        <?php } ?>
         <td>
             <label for="removeoutcomes"><?php print_string('outcomescourse', 'grades'); ?></label>
             <br />
             <select id="removeoutcomes" size="20" name="removeoutcomes[]" multiple="multiple">
             <?php
-            foreach ($courseoutcomes as $outcome) {
-                echo '<option value="'.$outcome->id.'">'.$outcome->get_name().'</option>';
+            if ($co_standard_notused) {
+                echo '<optgroup label="'.get_string('outcomescoursenotused', 'grades').'">';
+                foreach ($co_standard_notused as $outcome) {
+                    echo '<option value="'.$outcome->id.'">'.$outcome->get_name().'</option>';
+                }
+                echo '</optgroup>';
+            }
+            if ($co_standard_used) {
+                echo '<optgroup label="'.get_string('outcomescourseused', 'grades').'">';
+                foreach ($co_standard_used as $outcome) {
+                    echo '<option value="'.$outcome->id.'">'.$outcome->get_name().'</option>';
+                }
+                echo '</optgroup>';
+            }
+            if ($co_custom) {
+                echo '<optgroup label="'.get_string('outcomescoursecustom', 'grades').'">';
+                foreach ($co_custom as $outcome) {
+                    echo '<option value="'.$outcome->id.'">'.$outcome->get_name().'</option>';
+                }
+                echo '</optgroup>';
             }
             ?>
             </select>
index 07b6ed323aec8f140beb0d35d6771714650deab4..5b3e274e15c9e2b46fd97b3820ad52851db92829 100644 (file)
@@ -113,7 +113,9 @@ if ($courseid and $outcomes = grade_outcome::fetch_all_local($courseid)) {
                 $caneditthisscale = has_capability('moodle/course:managescales', $context);
             }
             if ($caneditthisscale) {
-                $line[] = '<a href="'.$CFG->wwwroot.'/grade/edit/scale/edit.php?courseid='.$courseid.'&amp;id='.$scale->id.'">'.$scale->get_name().'</a>';
+                $url = $CFG->wwwroot.'/grade/edit/scale/edit.php?courseid='.$courseid.'&amp;id='.$scale->id;
+                $url = $gpr->add_url_params($url);
+                $line[] = '<a href="'.$url.'">'.$scale->get_name().'</a>';
             } else {
                 $line[] = $scale->get_name();
             }
index 16774abf551b58e073cd8d24d6b221c95bd9b5d8..ae43b7405c32a5dfbe4c4eac4c1ec4675644899b 100644 (file)
@@ -229,9 +229,14 @@ $string['outcomeitemsedit'] = 'Edit outcome item';
 $string['outcomes'] = 'Outcomes';
 $string['outcomescustom'] = 'Custom outcomes';
 $string['outcomescourse'] = 'Outcomes used in course';
+$string['outcomescoursecustom'] = 'Custom used (no remove)';
+$string['outcomescoursenotused'] = 'Standard not used';
+$string['outcomescourseused'] = 'Standard used (no remove)';
+$string['outcomescourse'] = 'Outcomes used in course';
 $string['outcomename'] = 'Outcome name';
 $string['outcomereport'] = 'Outcome report';
 $string['outcomesstandard'] = 'Standard outcomes';
+$string['outcomesstandardavailable'] = 'Available standard outcomes';
 $string['outcomestandard'] = 'Standard outcome';
 $string['outcomes'] = 'Outcomes';
 $string['overridden'] = 'Overridden';