MDL-42531 assign: refactor batch operations to use forms properly

Avoids a lot of ugly optional_param() use. Also fixes the
non-functional cancel buttons.
This commit is contained in:
Jonathon Fowler 2014-05-07 16:11:23 +10:00
parent f8fa440649
commit c462c35b95
5 changed files with 150 additions and 103 deletions

View File

@ -42,17 +42,17 @@ class mod_assign_batch_set_allocatedmarker_form extends moodleform {
$mform = $this->_form; $mform = $this->_form;
$params = $this->_customdata; $params = $this->_customdata;
$mform->addElement('header', 'general', get_string('batchsetallocatedmarker', 'assign', count($params['users']))); $mform->addElement('header', 'general', get_string('batchsetallocatedmarker', 'assign', $params['userscount']));
$mform->addElement('static', 'userslist', get_string('selectedusers', 'assign'), $params['usershtml']); $mform->addElement('static', 'userslist', get_string('selectedusers', 'assign'), $params['usershtml']);
$options = $params['markers']; $options = $params['markers'];
$mform->addElement('select', 'allocatedmarker', get_string('allocatedmarker', 'assign'), $options); $mform->addElement('select', 'allocatedmarker', get_string('allocatedmarker', 'assign'), $options);
$mform->addElement('hidden', 'id', $params['cm']); $mform->addElement('hidden', 'id');
$mform->setType('id', PARAM_INT); $mform->setType('id', PARAM_INT);
$mform->addElement('hidden', 'action', 'setbatchmarkingallocation'); $mform->addElement('hidden', 'action', 'setbatchmarkingallocation');
$mform->setType('action', PARAM_ALPHA); $mform->setType('action', PARAM_ALPHA);
$mform->addElement('hidden', 'selectedusers', implode(',', $params['users'])); $mform->addElement('hidden', 'selectedusers');
$mform->setType('selectedusers', PARAM_SEQUENCE); $mform->setType('selectedusers', PARAM_SEQUENCE);
$this->add_action_buttons(true, get_string('savechanges')); $this->add_action_buttons(true, get_string('savechanges'));

View File

@ -41,7 +41,7 @@ class mod_assign_batch_set_marking_workflow_state_form extends moodleform {
public function definition() { public function definition() {
$mform = $this->_form; $mform = $this->_form;
$params = $this->_customdata; $params = $this->_customdata;
$formheader = get_string('batchsetmarkingworkflowstateforusers', 'assign', count($params['users'])); $formheader = get_string('batchsetmarkingworkflowstateforusers', 'assign', $params['userscount']);
$mform->addElement('header', 'general', $formheader); $mform->addElement('header', 'general', $formheader);
$mform->addElement('static', 'userslist', get_string('selectedusers', 'assign'), $params['usershtml']); $mform->addElement('static', 'userslist', get_string('selectedusers', 'assign'), $params['usershtml']);
@ -49,11 +49,11 @@ class mod_assign_batch_set_marking_workflow_state_form extends moodleform {
$options = $params['markingworkflowstates']; $options = $params['markingworkflowstates'];
$mform->addElement('select', 'markingworkflowstate', get_string('markingworkflowstate', 'assign'), $options); $mform->addElement('select', 'markingworkflowstate', get_string('markingworkflowstate', 'assign'), $options);
$mform->addElement('hidden', 'id', $params['cm']); $mform->addElement('hidden', 'id');
$mform->setType('id', PARAM_INT); $mform->setType('id', PARAM_INT);
$mform->addElement('hidden', 'action', 'setbatchmarkingworkflowstate'); $mform->addElement('hidden', 'action', 'setbatchmarkingworkflowstate');
$mform->setType('action', PARAM_ALPHA); $mform->setType('action', PARAM_ALPHA);
$mform->addElement('hidden', 'selectedusers', implode(',', $params['users'])); $mform->addElement('hidden', 'selectedusers');
$mform->setType('selectedusers', PARAM_SEQUENCE); $mform->setType('selectedusers', PARAM_SEQUENCE);
$this->add_action_buttons(true, get_string('savechanges')); $this->add_action_buttons(true, get_string('savechanges'));

View File

@ -3493,9 +3493,8 @@ class assign {
$users = $submitteddata->selectedusers; $users = $submitteddata->selectedusers;
$userlist = explode(',', $users); $userlist = explode(',', $users);
$formparams = array('cm'=>$this->get_course_module()->id, $formdata = array('id' => $this->get_course_module()->id,
'users'=>$userlist, 'selectedusers' => $users);
'context'=>$this->get_context());
$usershtml = ''; $usershtml = '';
@ -3519,10 +3518,14 @@ class assign {
$usercount += 1; $usercount += 1;
} }
$formparams['usershtml'] = $usershtml; $formparams = array(
$formparams['markingworkflowstates'] = $this->get_marking_workflow_states_for_current_user(); 'userscount' => count($userlist),
'usershtml' => $usershtml,
'markingworkflowstates' => $this->get_marking_workflow_states_for_current_user()
);
$mform = new mod_assign_batch_set_marking_workflow_state_form(null, $formparams); $mform = new mod_assign_batch_set_marking_workflow_state_form(null, $formparams);
$mform->set_data($formdata); // Initialises the hidden elements.
$o .= $this->get_renderer()->header(); $o .= $this->get_renderer()->header();
$o .= $this->get_renderer()->render(new assign_form('setworkflowstate', $mform)); $o .= $this->get_renderer()->render(new assign_form('setworkflowstate', $mform));
$o .= $this->view_footer(); $o .= $this->view_footer();
@ -3549,9 +3552,8 @@ class assign {
$users = $submitteddata->selectedusers; $users = $submitteddata->selectedusers;
$userlist = explode(',', $users); $userlist = explode(',', $users);
$formparams = array('cm'=>$this->get_course_module()->id, $formdata = array('id' => $this->get_course_module()->id,
'users'=>$userlist, 'selectedusers' => $users);
'context'=>$this->get_context());
$usershtml = ''; $usershtml = '';
@ -3575,7 +3577,11 @@ class assign {
$usercount += 1; $usercount += 1;
} }
$formparams['usershtml'] = $usershtml; $formparams = array(
'userscount' => count($userlist),
'usershtml' => $usershtml,
);
$markers = get_users_by_capability($this->get_context(), 'mod/assign:grade'); $markers = get_users_by_capability($this->get_context(), 'mod/assign:grade');
$markerlist = array(); $markerlist = array();
foreach ($markers as $marker) { foreach ($markers as $marker) {
@ -3585,6 +3591,7 @@ class assign {
$formparams['markers'] = $markerlist; $formparams['markers'] = $markerlist;
$mform = new mod_assign_batch_set_allocatedmarker_form(null, $formparams); $mform = new mod_assign_batch_set_allocatedmarker_form(null, $formparams);
$mform->set_data($formdata); // Initialises the hidden elements.
$o .= $this->get_renderer()->header(); $o .= $this->get_renderer()->header();
$o .= $this->get_renderer()->render(new assign_form('setworkflowstate', $mform)); $o .= $this->get_renderer()->render(new assign_form('setworkflowstate', $mform));
$o .= $this->view_footer(); $o .= $this->view_footer();
@ -6114,13 +6121,26 @@ class assign {
* @return void * @return void
*/ */
protected function process_set_batch_marking_workflow_state() { protected function process_set_batch_marking_workflow_state() {
global $DB; global $CFG, $DB;
require_sesskey(); // Include batch marking workflow form.
require_once($CFG->dirroot . '/mod/assign/batchsetmarkingworkflowstateform.php');
$batchusers = required_param('selectedusers', PARAM_TEXT); $formparams = array(
$state = required_param('markingworkflowstate', PARAM_ALPHA); 'userscount' => 0, // This form is never re-displayed, so we don't need to
$useridlist = explode(',', $batchusers); 'usershtml' => '', // initialise these parameters with real information.
'markingworkflowstates' => $this->get_marking_workflow_states_for_current_user()
);
$mform = new mod_assign_batch_set_marking_workflow_state_form(null, $formparams);
if ($mform->is_cancelled()) {
return true;
}
if ($formdata = $mform->get_data()) {
$useridlist = explode(',', $formdata->selectedusers);
$state = $formdata->markingworkflowstate;
foreach ($useridlist as $userid) { foreach ($useridlist as $userid) {
$flags = $this->get_user_flags($userid, true); $flags = $this->get_user_flags($userid, true);
@ -6145,6 +6165,7 @@ class assign {
} }
} }
} }
}
/** /**
* Set the marking allocation for multiple users * Set the marking allocation for multiple users
@ -6152,16 +6173,33 @@ class assign {
* @return void * @return void
*/ */
protected function process_set_batch_marking_allocation() { protected function process_set_batch_marking_allocation() {
global $DB; global $CFG, $DB;
require_sesskey(); // Include batch marking allocation form.
require_capability('mod/assign:manageallocations', $this->context); require_once($CFG->dirroot . '/mod/assign/batchsetallocatedmarkerform.php');
$batchusers = required_param('selectedusers', PARAM_TEXT); $formparams = array(
$markerid = required_param('allocatedmarker', PARAM_INT); 'userscount' => 0, // This form is never re-displayed, so we don't need to
$marker = $DB->get_record('user', array('id' => $markerid), '*', MUST_EXIST); 'usershtml' => '' // initialise these parameters with real information.
);
$useridlist = explode(',', $batchusers); $markers = get_users_by_capability($this->get_context(), 'mod/assign:grade');
$markerlist = array();
foreach ($markers as $marker) {
$markerlist[$marker->id] = fullname($marker);
}
$formparams['markers'] = $markerlist;
$mform = new mod_assign_batch_set_allocatedmarker_form(null, $formparams);
if ($mform->is_cancelled()) {
return true;
}
if ($formdata = $mform->get_data()) {
$useridlist = explode(',', $formdata->selectedusers);
$marker = $DB->get_record('user', array('id' => $formdata->allocatedmarker), '*', MUST_EXIST);
foreach ($useridlist as $userid) { foreach ($useridlist as $userid) {
$flags = $this->get_user_flags($userid, true); $flags = $this->get_user_flags($userid, true);
@ -6181,6 +6219,7 @@ class assign {
} }
} }
} }
}
/** /**

View File

@ -263,18 +263,32 @@ class testable_assign extends assign {
} }
public function testable_process_set_batch_marking_allocation($selectedusers, $markerid) { public function testable_process_set_batch_marking_allocation($selectedusers, $markerid) {
// Ugly hack to get something into the method. global $CFG;
global $_POST; require_once($CFG->dirroot . '/mod/assign/batchsetallocatedmarkerform.php');
$_POST['selectedusers'] = $selectedusers;
$_POST['allocatedmarker'] = $markerid; // Simulate the form submission.
$data = array();
$data['id'] = $this->get_course_module()->id;
$data['selectedusers'] = $selectedusers;
$data['allocatedmarker'] = $markerid;
$data['action'] = 'setbatchmarkingallocation';
mod_assign_batch_set_allocatedmarker_form::mock_submit($data);
return parent::process_set_batch_marking_allocation(); return parent::process_set_batch_marking_allocation();
} }
public function testable_process_set_batch_marking_workflow_state($selectedusers, $state) { public function testable_process_set_batch_marking_workflow_state($selectedusers, $state) {
// Ugly hack to get something into the method. global $CFG;
global $_POST; require_once($CFG->dirroot . '/mod/assign/batchsetmarkingworkflowstateform.php');
$_POST['selectedusers'] = $selectedusers;
$_POST['markingworkflowstate'] = $state; // Simulate the form submission.
$data = array();
$data['id'] = $this->get_course_module()->id;
$data['selectedusers'] = $selectedusers;
$data['markingworkflowstate'] = $state;
$data['action'] = 'setbatchmarkingworkflowstate';
mod_assign_batch_set_marking_workflow_state_form::mock_submit($data);
return parent::process_set_batch_marking_workflow_state(); return parent::process_set_batch_marking_workflow_state();
} }
@ -291,47 +305,41 @@ class testable_assign extends assign {
return parent::get_graders($userid); return parent::get_graders($userid);
} }
public function testable_view_batch_set_workflow_state() { public function testable_view_batch_set_workflow_state($selectedusers) {
global $CFG; $mform = $this->testable_grading_batch_operations_form('setmarkingworkflowstate', $selectedusers);
require_once($CFG->dirroot . '/mod/assign/batchsetmarkingworkflowstateform.php');
// Mock submit data.
$data = array();
$data['selectedusers'] = '1';
mod_assign_batch_set_marking_workflow_state_form::mock_submit($data);
// Set required variables in the form - not valid just allows us to continue.
$formparams = array();
$formparams['users'] = array(1);
$formparams['usershtml'] = 1;
$formparams['cm'] = $this->get_course_module()->id;
$formparams['context'] = $this->get_context();
$formparams['markingworkflowstates'] = 1;
$mform = new mod_assign_batch_set_marking_workflow_state_form('', $formparams);
return parent::view_batch_set_workflow_state($mform); return parent::view_batch_set_workflow_state($mform);
} }
public function testable_view_batch_markingallocation() { public function testable_view_batch_markingallocation($selectedusers) {
global $CFG; $mform = $this->testable_grading_batch_operations_form('setmarkingallocation', $selectedusers);
require_once($CFG->dirroot . '/mod/assign/batchsetallocatedmarkerform.php');
// Mock submit data.
$data = array();
$data['selectedusers'] = '1';
mod_assign_batch_set_allocatedmarker_form::mock_submit($data);
// Set required variables in the form - not valid just allows us to continue.
$formparams = array();
$formparams['users'] = array(1);
$formparams['usershtml'] = 1;
$formparams['cm'] = $this->get_course_module()->id;
$formparams['context'] = $this->get_context();
$formparams['markers'] = 1;
$mform = new mod_assign_batch_set_allocatedmarker_form('', $formparams);
return parent::view_batch_markingallocation($mform); return parent::view_batch_markingallocation($mform);
} }
public function testable_grading_batch_operations_form($operation, $selectedusers) {
global $CFG;
require_once($CFG->dirroot . '/mod/assign/gradingbatchoperationsform.php');
// Mock submit the grading operations form.
$data = array();
$data['id'] = $this->get_course_module()->id;
$data['selectedusers'] = $selectedusers;
$data['returnaction'] = 'grading';
$data['operation'] = $operation;
mod_assign_grading_batch_operations_form::mock_submit($data);
// Set required variables in the form.
$formparams = array();
$formparams['submissiondrafts'] = 1;
$formparams['duedate'] = 1;
$formparams['attemptreopenmethod'] = ASSIGN_ATTEMPT_REOPEN_METHOD_MANUAL;
$formparams['feedbackplugins'] = array();
$formparams['markingworkflow'] = 1;
$formparams['markingallocation'] = 1;
$formparams['cm'] = $this->get_course_module()->id;
$formparams['context'] = $this->get_context();
$mform = new mod_assign_grading_batch_operations_form(null, $formparams);
return $mform;
}
} }

View File

@ -912,7 +912,7 @@ class assign_events_testcase extends mod_assign_base_testcase {
// Trigger and capture the event. // Trigger and capture the event.
$sink = $this->redirectEvents(); $sink = $this->redirectEvents();
$assign->testable_view_batch_set_workflow_state(); $assign->testable_view_batch_set_workflow_state($this->students[0]->id);
$events = $sink->get_events(); $events = $sink->get_events();
$event = reset($events); $event = reset($events);
@ -939,7 +939,7 @@ class assign_events_testcase extends mod_assign_base_testcase {
// Trigger and capture the event. // Trigger and capture the event.
$sink = $this->redirectEvents(); $sink = $this->redirectEvents();
$assign->testable_view_batch_markingallocation(); $assign->testable_view_batch_markingallocation($this->students[0]->id);
$events = $sink->get_events(); $events = $sink->get_events();
$event = reset($events); $event = reset($events);