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. 13 // 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/>. 16 17 /** 18 * Allows to choose a form from the list of available templates 19 * 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 23 */ 24 25 require(__DIR__.'/../../config.php'); 26 require_once($CFG->dirroot.'/grade/grading/lib.php'); 27 require_once($CFG->dirroot.'/grade/grading/pick_form.php'); 28 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 33 34 // the manager of the target area 35 $targetmanager = get_grading_manager($targetid); 36 37 if ($targetmanager->get_context()->contextlevel < CONTEXT_COURSE) { 38 throw new coding_exception('Unsupported gradable area context level'); 39 } 40 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); 45 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))); 49 } 50 51 list($context, $course, $cm) = get_context_info_array($targetmanager->get_context()->id); 52 53 require_login($course, true, $cm); 54 require_capability('moodle/grade:managegradingforms', $context); 55 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()); 59 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'); 66 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'); 78 } 79 if (!$sourcecontroller->is_form_defined()) { 80 throw new moodle_exception('form_definition_mismatch', 'core_grading'); 81 } 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))); 99 } 100 } 101 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'); 109 } 110 if (!$sourcecontroller->is_form_defined()) { 111 throw new moodle_exception('form_definition_mismatch', 'core_grading'); 112 } 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'); 118 } 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); 131 } 132 } 133 134 $searchform = new grading_search_template_form($PAGE->url, null, 'GET', '', array('class' => 'templatesearchform')); 135 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; 142 } 143 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'); 151 152 $sql .= " WHERE gd.method = ?"; 153 154 $params = array($method); 155 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; 160 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)); 167 } 168 169 if ($tokens) { 170 $subsql = array(); 171 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).'%'; 176 } 177 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).'%'; 182 } 183 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); 189 } 190 191 $sql .= " AND ((" . join(")\n OR (", $subsql) . "))"; 192 } 193 194 $sql .= " ORDER BY gd.name"; 195 196 $rs = $DB->get_recordset_sql($sql, $params); 197 198 echo $output->header(); 199 $searchform->display(); 200 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'); 219 } 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/valid', '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'); 232 } 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/valid', 'pick ownform'); 236 } 237 $out .= $output->box(join(' ', $actions), 'template-actions'); 238 $out .= $output->box($controller->get_formatted_description(), 'template-description'); 239 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); 245 } 246 $rs->close(); 247 248 if (!$found) { 249 echo $output->heading(get_string('nosharedformfound', 'core_grading')); 250 } 251 252 echo $output->single_button( 253 new moodle_url('/grade/grading/manage.php', array('areaid' => $targetid)), 254 get_string('back'), 'get'); 255 256 echo $output->footer(); 257
title
Description
Body
title
Description
Body
title
Description
Body
title
Body