MDL-21781 cohorts may be moved to different course categories/system context
authorPetr Skoda <skodak@moodle.org>
Fri, 23 Apr 2010 09:13:49 +0000 (09:13 +0000)
committerPetr Skoda <skodak@moodle.org>
Fri, 23 Apr 2010 09:13:49 +0000 (09:13 +0000)
cohort/edit.php
cohort/edit_form.php

index 76f7be2..fa03108 100644 (file)
@@ -99,8 +99,7 @@ if ($cohort->id) {
 $PAGE->set_title($strheading);
 $PAGE->navbar->add($strheading);
 
-$editform = new cohort_edit_form(null, array('editoroptions'=>$editoroptions));
-$editform->set_data($cohort);
+$editform = new cohort_edit_form(null, array('editoroptions'=>$editoroptions, 'data'=>$cohort));
 
 if ($editform->is_cancelled()) {
     redirect($returnurl);
@@ -114,7 +113,8 @@ if ($editform->is_cancelled()) {
         cohort_add_cohort($data);
     }
 
-    redirect($returnurl);
+    // use new context id, it could have been changed
+    redirect(new moodle_url('/cohort/index.php', array('contextid'=>$data->contextid)));
 }
 
 echo $OUTPUT->header();
index e286a23..c81c0c5 100644 (file)
@@ -29,17 +29,21 @@ require_once($CFG->dirroot . '/lib/formslib.php');
 class cohort_edit_form extends moodleform {
 
     /**
-     * Define the form
+     * Define the cohort edit form
      */
-    function definition() {
+    public function definition() {
 
         $mform = $this->_form;
         $editoroptions = $this->_customdata['editoroptions'];
+        $cohort = $this->_customdata['data'];
 
         $mform->addElement('text', 'name', get_string('name', 'cohort'), 'maxlength="254" size="50"');
         $mform->addRule('name', get_string('required'), 'required', null, 'client');
         $mform->setType('name', PARAM_MULTILANG);
 
+        $options = $this->get_category_options($cohort->contextid);
+        $mform->addElement('select', 'contextid', get_string('context', 'role'), $options);
+
         $mform->addElement('text', 'idnumber', get_string('idnumber', 'cohort'), 'maxlength="254" size="50"');
         $mform->setType('name', PARAM_RAW);
 
@@ -49,13 +53,12 @@ class cohort_edit_form extends moodleform {
         $mform->addElement('hidden', 'id');
         $mform->setType('id', PARAM_INT);
 
-        $mform->addElement('hidden', 'contextid');
-        $mform->setType('contextid', PARAM_INT);
-
         $this->add_action_buttons();
+
+        $this->set_data($cohort);
     }
 
-    function validation($data, $files) {
+    public function validation($data, $files) {
         global $DB;
 
         $errors = parent::validation($data, $files);
@@ -76,5 +79,26 @@ class cohort_edit_form extends moodleform {
 
         return $errors;
     }
+
+    protected function get_category_options($currentcontextid) {
+        $displaylist = array();
+        $parentlist = array();
+        make_categories_list($displaylist, $parentlist, 'moodle/cohort:manage');
+        $options = array();
+        $syscontext = get_context_instance(CONTEXT_SYSTEM);
+        if (has_capability('moodle/cohort:manage', $syscontext)) {
+            $options[$syscontext->id] = print_context_name($syscontext);
+        }
+        foreach ($displaylist as $cid=>$name) {
+            $context = get_context_instance(CONTEXT_COURSECAT, $cid, MUST_EXIST);
+            $options[$context->id] = $name;
+        }
+        // always add current - this is not likely, but if the logic get's changed it might be a problem
+        if (!isset($options[$currentcontextid])) {
+            $context = get_context_instance_by_id($currentcontextid, MUST_EXIST);
+            $options[$context->id] = print_context_name($syscontext);
+        }
+        return $options;
+    }
 }
     
\ No newline at end of file