Merge branch 'MDL-40255_M25' of git://github.com/lazydaisy/moodle into MOODLE_25_STABLE
[moodle.git] / grade / grading / pick.php
blob075ca272e0bb05c9b30da5c8a0ecf909a6b52ccc
1 <?php
2 // This file is part of Moodle - http://moodle.org/
3 //
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
17 /**
18 * Allows to choose a form from the list of available templates
20 * @package core_grading
21 * @copyright 2011 David Mudrak <david@moodle.com>
22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
25 require_once(dirname(dirname(dirname(__FILE__))).'/config.php');
26 require_once($CFG->dirroot.'/grade/grading/lib.php');
27 require_once($CFG->dirroot.'/grade/grading/pick_form.php');
29 $targetid = required_param('targetid', PARAM_INT); // area we are coming from
30 $pick = optional_param('pick', null, PARAM_INT); // create new form from this template
31 $remove = optional_param('remove', null, PARAM_INT); // remove this template
32 $confirmed = optional_param('confirmed', false, PARAM_BOOL); // is the action confirmed
34 // the manager of the target area
35 $targetmanager = get_grading_manager($targetid);
37 if ($targetmanager->get_context()->contextlevel < CONTEXT_COURSE) {
38 throw new coding_exception('Unsupported gradable area context level');
41 // currently active method in the target area
42 $method = $targetmanager->get_active_method();
43 $targetcontroller = $targetmanager->get_controller($method);
44 $targetcontrollerclass = get_class($targetcontroller);
46 // make sure there is no such form defined in the target area
47 if ($targetcontroller->is_form_defined()) {
48 redirect(new moodle_url('/grade/grading/manage.php', array('areaid' => $targetid)));
51 list($context, $course, $cm) = get_context_info_array($targetmanager->get_context()->id);
53 require_login($course, true, $cm);
54 require_capability('moodle/grade:managegradingforms', $context);
56 // user's capability in the templates bank
57 $canshare = has_capability('moodle/grade:sharegradingforms', context_system::instance());
58 $canmanage = has_capability('moodle/grade:managesharedforms', context_system::instance());
60 // setup the page
61 $PAGE->set_url(new moodle_url('/grade/grading/pick.php', array('targetid' => $targetid)));
62 navigation_node::override_active_url($targetmanager->get_management_url());
63 $PAGE->set_title(get_string('gradingmanagement', 'core_grading'));
64 $PAGE->set_heading(get_string('gradingmanagement', 'core_grading'));
65 $output = $PAGE->get_renderer('core_grading');
67 // process picking a template
68 if ($pick) {
69 $sourceid = $DB->get_field('grading_definitions', 'areaid', array('id' => $pick), MUST_EXIST);
70 $sourcemanager = get_grading_manager($sourceid);
71 $sourcecontroller = $sourcemanager->get_controller($method);
72 if (!$sourcecontroller->is_shared_template() and !$sourcecontroller->is_own_form()) {
73 // note that we don't actually check whether the user has still the capability
74 // moodle/grade:managegradingforms in the source area. so when users loose
75 // their teacher role in a course, they can't access the course but they can
76 // still copy the forms they have created there.
77 throw new moodle_exception('attempt_to_pick_others_form', 'core_grading');
79 if (!$sourcecontroller->is_form_defined()) {
80 throw new moodle_exception('form_definition_mismatch', 'core_grading');
82 $definition = $sourcecontroller->get_definition();
83 if (!$confirmed) {
84 echo $output->header();
85 echo $output->confirm(get_string('templatepickconfirm', 'core_grading',array(
86 'formname' => s($definition->name),
87 'component' => $targetmanager->get_component_title(),
88 'area' => $targetmanager->get_area_title())),
89 new moodle_url($PAGE->url, array('pick' => $pick, 'confirmed' => 1)),
90 $PAGE->url);
91 echo $output->box($sourcecontroller->render_preview($PAGE), 'template-preview-confirm');
92 echo $output->footer();
93 die();
94 } else {
95 require_sesskey();
96 $targetcontroller->update_definition($sourcecontroller->get_definition_copy($targetcontroller));
97 $DB->set_field('grading_definitions', 'timecopied', time(), array('id' => $definition->id));
98 redirect(new moodle_url('/grade/grading/manage.php', array('areaid' => $targetid)));
102 // process removing a template
103 if ($remove) {
104 $sourceid = $DB->get_field('grading_definitions', 'areaid', array('id' => $remove), MUST_EXIST);
105 $sourcemanager = get_grading_manager($sourceid);
106 $sourcecontroller = $sourcemanager->get_controller($method);
107 if (!$sourcecontroller->is_shared_template()) {
108 throw new moodle_exception('attempt_to_delete_nontemplate', 'core_grading');
110 if (!$sourcecontroller->is_form_defined()) {
111 throw new moodle_exception('form_definition_mismatch', 'core_grading');
113 $definition = $sourcecontroller->get_definition();
114 if ($canmanage or ($canshare and ($definition->usercreated == $USER->id))) {
115 // ok, this user can drop the template
116 } else {
117 throw new moodle_exception('no_permission_to_remove_template', 'core_grading');
119 if (!$confirmed) {
120 echo $output->header();
121 echo $output->confirm(get_string('templatedeleteconfirm', 'core_grading', s($definition->name)),
122 new moodle_url($PAGE->url, array('remove' => $remove, 'confirmed' => 1)),
123 $PAGE->url);
124 echo $output->box($sourcecontroller->render_preview($PAGE), 'template-preview-confirm');
125 echo $output->footer();
126 die();
127 } else {
128 require_sesskey();
129 $sourcecontroller->delete_definition();
130 redirect($PAGE->url);
134 $searchform = new grading_search_template_form($PAGE->url, null, 'GET', '', array('class' => 'templatesearchform'));
136 if ($searchdata = $searchform->get_data()) {
137 $tokens = grading_manager::tokenize($searchdata->needle);
138 $includeownforms = (!empty($searchdata->mode));
139 } else {
140 $tokens = array();
141 $includeownforms = false;
144 // construct the SQL to find all matching templates
145 $sql = "SELECT DISTINCT gd.id, gd.areaid, gd.name, gd.usercreated
146 FROM {grading_definitions} gd
147 JOIN {grading_areas} ga ON (gd.areaid = ga.id)
148 JOIN {context} cx ON (ga.contextid = cx.id)";
149 // join method-specific tables from the plugin scope
150 $sql .= $targetcontrollerclass::sql_search_from_tables('gd.id');
152 $sql .= " WHERE gd.method = ?";
154 $params = array($method);
156 if (!$includeownforms) {
157 // search for public templates only
158 $sql .= " AND ga.contextid = ? AND ga.component = 'core_grading'";
159 $params[] = context_system::instance()->id;
161 } else {
162 // search both templates and own forms in other areas
163 $sql .= " AND ((ga.contextid = ? AND ga.component = 'core_grading')
164 OR (gd.usercreated = ? AND gd.status = ?))";
165 $params = array_merge($params, array(context_system::instance()->id, $USER->id,
166 gradingform_controller::DEFINITION_STATUS_READY));
169 if ($tokens) {
170 $subsql = array();
172 // search for any of the tokens in the definition name
173 foreach ($tokens as $token) {
174 $subsql[] = $DB->sql_like('gd.name', '?', false, false);
175 $params[] = '%'.$DB->sql_like_escape($token).'%';
178 // search for any of the tokens in the definition description
179 foreach ($tokens as $token) {
180 $subsql[] = $DB->sql_like('gd.description', '?', false, false);
181 $params[] = '%'.$DB->sql_like_escape($token).'%';
184 // search for the needle in method-specific tables
185 foreach ($tokens as $token) {
186 list($methodsql, $methodparams) = $targetcontrollerclass::sql_search_where($token);
187 $subsql = array_merge($subsql, $methodsql);
188 $params = array_merge($params, $methodparams);
191 $sql .= " AND ((" . join(")\n OR (", $subsql) . "))";
194 $sql .= " ORDER BY gd.name";
196 $rs = $DB->get_recordset_sql($sql, $params);
198 echo $output->header();
199 $searchform->display();
201 $found = 0;
202 foreach ($rs as $template) {
203 $found++;
204 $out = '';
205 $manager = get_grading_manager($template->areaid);
206 $controller = $manager->get_controller($method);
207 if ($controller->is_shared_template()) {
208 $templatetag = html_writer::tag('span', get_string('templatetypeshared', 'core_grading'),
209 array('class' => 'type shared'));
210 $templatesrc = '';
211 } else if ($controller->is_own_form()) {
212 $templatetag = html_writer::tag('span', get_string('templatetypeown', 'core_grading'),
213 array('class' => 'type ownform'));
214 $templatesrc = get_string('templatesource', 'core_grading', array(
215 'component' => $manager->get_component_title(),
216 'area' => $manager->get_area_title()));
217 } else {
218 throw new coding_exception('Something is wrong, the displayed form must be either template or own form');
220 $out .= $output->heading(s($template->name).' '.$templatetag, 2, 'template-name');
221 $out .= $output->container($templatesrc, 'template-source');
222 $out .= $output->box($controller->render_preview($PAGE), 'template-preview');
223 $actions = array();
224 if ($controller->is_shared_template()) {
225 $actions[] = $output->pick_action_icon(new moodle_url($PAGE->url, array('pick' => $template->id)),
226 get_string('templatepick', 'core_grading'), 'i/tick_green_big', 'pick template');
227 if ($canmanage or ($canshare and ($template->usercreated == $USER->id))) {
228 //$actions[] = $output->pick_action_icon(new moodle_url($PAGE->url, array('edit' => $template->id)),
229 // get_string('templateedit', 'core_grading'), 'i/edit', 'edit');
230 $actions[] = $output->pick_action_icon(new moodle_url($PAGE->url, array('remove' => $template->id)),
231 get_string('templatedelete', 'core_grading'), 't/delete', 'remove');
233 } else if ($controller->is_own_form()) {
234 $actions[] = $output->pick_action_icon(new moodle_url($PAGE->url, array('pick' => $template->id)),
235 get_string('templatepickownform', 'core_grading'), 'i/tick_green_big', 'pick ownform');
237 $out .= $output->box(join(' ', $actions), 'template-actions');
238 $out .= $output->box($controller->get_formatted_description(), 'template-description');
240 // ideally we should highlight just the name, description and the fields
241 // in the preview that were actually searched. to make our life easier, we
242 // simply highlight the tokens everywhere they appear, even if that exact
243 // piece was not searched.
244 echo highlight(join(' ', $tokens), $out);
246 $rs->close();
248 if (!$found) {
249 echo $output->heading(get_string('nosharedformfound', 'core_grading'));
252 echo $output->single_button(
253 new moodle_url('/grade/grading/manage.php', array('areaid' => $targetid)),
254 get_string('back'), 'get');
256 echo $output->footer();