MDl-29189 course Increased the shortname field length so that it is more usable now...
[moodle.git] / mod / feedback / mapcourse.php
1 <?php
3 /**
4  * print the form to map courses for global feedbacks
5  *
6  * @author Andreas Grabs
7  * @license http://www.gnu.org/copyleft/gpl.html GNU Public License
8  * @package feedback
9  */
11 require_once("../../config.php");
12 require_once("lib.php");
13 require_once("$CFG->libdir/tablelib.php");
15 $id = required_param('id', PARAM_INT); // Course Module ID, or
16 $searchcourse = optional_param('searchcourse', '', PARAM_NOTAGS);
17 $coursefilter = optional_param('coursefilter', '', PARAM_INT);
18 $courseid = optional_param('courseid', false, PARAM_INT);
20 $url = new moodle_url('/mod/feedback/mapcourse.php', array('id'=>$id));
21 if ($searchcourse !== '') {
22     $url->param('searchcourse', $searchcourse);
23 }
24 if ($coursefilter !== '') {
25     $url->param('coursefilter', $coursefilter);
26 }
27 if ($courseid !== false) {
28     $url->param('courseid', $courseid);
29 }
30 $PAGE->set_url($url);
32 if(($formdata = data_submitted()) AND !confirm_sesskey()) {
33     print_error('invalidsesskey');
34 }
36 // $SESSION->feedback->current_tab = 'mapcourse';
37 $current_tab = 'mapcourse';
39 if (! $cm = get_coursemodule_from_id('feedback', $id)) {
40     print_error('invalidcoursemodule');
41 }
43 if (! $course = $DB->get_record("course", array("id"=>$cm->course))) {
44     print_error('coursemisconf');
45 }
47 if (! $feedback = $DB->get_record("feedback", array("id"=>$cm->instance))) {
48     print_error('invalidcoursemodule');
49 }
51 if (!$context = get_context_instance(CONTEXT_MODULE, $cm->id)) {
52         print_error('badcontext');
53 }
55 require_login($course->id, true, $cm);
57 require_capability('mod/feedback:mapcourse', $context);
59 if ($coursefilter) {
60     $map->feedbackid = $feedback->id;
61     $map->courseid = $coursefilter;
62     // insert a map only if it does exists yet
63     $sql = "SELECT id, feedbackid
64               FROM {feedback_sitecourse_map}
65              WHERE feedbackid = ? AND courseid = ?";
66     if (!$DB->get_records_sql($sql, array($map->feedbackid, $map->courseid))) {
67         $DB->insert_record('feedback_sitecourse_map', $map);
68     }
69 }
71 /// Print the page header
72 $strfeedbacks = get_string("modulenameplural", "feedback");
73 $strfeedback  = get_string("modulename", "feedback");
75 $PAGE->set_heading(format_string($course->fullname));
76 $PAGE->set_title(format_string($feedback->name));
77 echo $OUTPUT->header();
79 include('tabs.php');
81 echo $OUTPUT->box(get_string('mapcourseinfo', 'feedback'), 'generalbox boxaligncenter boxwidthwide');
82 echo $OUTPUT->box_start('generalbox boxaligncenter boxwidthwide');
83 echo '<form method="post">';
84 echo '<input type="hidden" name="id" value="'.$id.'" />';
85 echo '<input type="hidden" name="sesskey" value="'.sesskey().'" />';
87 $sql = "select c.id, c.shortname
88           from {course} c
89          where ".$DB->sql_like('c.shortname', '?', false)."
90                OR ".$DB->sql_like('c.fullname', '?', false);
91 $params = array("%{$searchcourse}%", "%{$searchcourse}%");
93 if (($courses = $DB->get_records_sql_menu($sql, $params)) && !empty($searchcourse)) {
94     echo ' ' . get_string('courses') . ': ';
95     echo html_writer::select($courses, 'coursefilter', $coursefilter);
96     echo '<input type="submit" value="'.get_string('mapcourse', 'feedback').'"/>';
97     echo $OUTPUT->help_icon('mapcourses', 'feedback');
98     echo '<input type="button" value="'.get_string('searchagain').'" onclick="document.location=\'mapcourse.php?id='.$id.'\'"/>';
99     echo '<input type="hidden" name="searchcourse" value="'.$searchcourse.'"/>';
100     echo '<input type="hidden" name="feedbackid" value="'.$feedback->id.'"/>';
101     echo $OUTPUT->help_icon('searchcourses', 'feedback');
102 } else {
103     echo '<input type="text" name="searchcourse" value="'.$searchcourse.'"/> <input type="submit" value="'.get_string('searchcourses').'"/>';
104     echo $OUTPUT->help_icon('searchcourses', 'feedback');
107 echo '</form>';
109 if($coursemap = feedback_get_courses_from_sitecourse_map($feedback->id)) {
110     $table = new flexible_table('coursemaps');
111     $table->define_columns( array('course'));
112     $table->define_headers( array(get_string('mappedcourses', 'feedback')));
114     $table->setup();
116     $unmapurl = new moodle_url('/mod/feedback/unmapcourse.php');
117     foreach ($coursemap as $cmap) {
118         $cmapcontext = get_context_instance(CONTEXT_COURSE, $cmap->id);
119         $cmapshortname = format_string($cmap->shortname, true, array('context' => $coursecontext));
120         $unmapurl->params(array('id'=>$id, 'cmapid'=>$cmap->id));
121         $table->add_data(array('<a href="'.$unmapurl->out().'"><img src="'.$OUTPUT->pix_url('t/delete') . '" alt="Delete" /></a> ('.$cmapshortname.') '.$cmap->fullname));
122     }
124     $table->print_html();
125 } else {
126     echo '<h3>'.get_string('mapcoursenone', 'feedback').'</h3>';
130 echo $OUTPUT->box_end();
132 echo $OUTPUT->footer();