Skip to content

Commit

Permalink
MDL-21781 cohorts may be moved to different course categories/system …
Browse files Browse the repository at this point in the history
…context
  • Loading branch information
skodak committed Apr 23, 2010
1 parent 864e280 commit 9e1065a
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 9 deletions.
6 changes: 3 additions & 3 deletions cohort/edit.php
Original file line number Diff line number Diff line change
Expand Up @@ -99,8 +99,7 @@
$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);
Expand All @@ -114,7 +113,8 @@
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();
Expand Down
36 changes: 30 additions & 6 deletions cohort/edit_form.php
Original file line number Diff line number Diff line change
Expand Up @@ -29,17 +29,21 @@
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);

Expand All @@ -49,13 +53,12 @@ function definition() {
$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);
Expand All @@ -76,5 +79,26 @@ function validation($data, $files) {

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;
}
}

0 comments on commit 9e1065a

Please sign in to comment.