mirror of
https://github.com/moodle/moodle.git
synced 2025-01-17 21:49:15 +01:00
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:
parent
f8fa440649
commit
c462c35b95
@ -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'));
|
||||||
|
|
||||||
|
@ -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'));
|
||||||
|
|
||||||
|
@ -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 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user