MDL-50015 mod_imscp: New WS mod_imscp_view_imscp
[moodle.git] / mod / survey / view.php
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/>.
17 /**
18  * This file is responsible for displaying the survey
19  *
20  * @package   mod_survey
21  * @copyright 1999 onwards Martin Dougiamas  {@link http://moodle.com}
22  * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
23  */
25 require_once("../../config.php");
26 require_once("lib.php");
28 $id = required_param('id', PARAM_INT);    // Course Module ID.
30 if (! $cm = get_coursemodule_from_id('survey', $id)) {
31     print_error('invalidcoursemodule');
32 }
34 if (! $course = $DB->get_record("course", array("id" => $cm->course))) {
35     print_error('coursemisconf');
36 }
38 $PAGE->set_url('/mod/survey/view.php', array('id' => $id));
39 require_login($course, false, $cm);
40 $context = context_module::instance($cm->id);
42 require_capability('mod/survey:participate', $context);
44 if (! $survey = $DB->get_record("survey", array("id" => $cm->instance))) {
45     print_error('invalidsurveyid', 'survey');
46 }
47 $trimmedintro = trim($survey->intro);
48 if (empty($trimmedintro)) {
49     $tempo = $DB->get_field("survey", "intro", array("id" => $survey->template));
50     $survey->intro = get_string($tempo, "survey");
51 }
53 if (! $template = $DB->get_record("survey", array("id" => $survey->template))) {
54     print_error('invalidtmptid', 'survey');
55 }
57 // Update 'viewed' state if required by completion system.
58 require_once($CFG->libdir . '/completionlib.php');
59 $completion = new completion_info($course);
60 $completion->set_module_viewed($cm);
62 $showscales = ($template->name != 'ciqname');
64 $strsurvey = get_string("modulename", "survey");
65 $PAGE->set_title($survey->name);
66 $PAGE->set_heading($course->fullname);
67 echo $OUTPUT->header();
68 echo $OUTPUT->heading($survey->name);
70 // Check to see if groups are being used in this survey.
71 if ($groupmode = groups_get_activity_groupmode($cm)) {   // Groups are being used.
72     $currentgroup = groups_get_activity_group($cm);
73 } else {
74     $currentgroup = 0;
75 }
76 $groupingid = $cm->groupingid;
78 if (has_capability('mod/survey:readresponses', $context) or ($groupmode == VISIBLEGROUPS)) {
79     $currentgroup = 0;
80 }
82 if (has_capability('mod/survey:readresponses', $context)) {
83     $numusers = survey_count_responses($survey->id, $currentgroup, $groupingid);
84     echo "<div class=\"reportlink\"><a href=\"report.php?id=$cm->id\">".
85           get_string("viewsurveyresponses", "survey", $numusers)."</a></div>";
86 } else if (!$cm->visible) {
87     notice(get_string("activityiscurrentlyhidden"));
88 }
90 if (!is_enrolled($context)) {
91     echo $OUTPUT->notification(get_string("guestsnotallowed", "survey"));
92 }
95 // Check the survey hasn't already been filled out.
97 if (survey_already_done($survey->id, $USER->id)) {
98     $params = array(
99         'objectid' => $survey->id,
100         'context' => $context,
101         'courseid' => $course->id,
102         'other' => array('viewed' => 'graph')
103     );
104     $event = \mod_survey\event\course_module_viewed::create($params);
105     $event->trigger();
106     $numusers = survey_count_responses($survey->id, $currentgroup, $groupingid);
108     if ($showscales) {
109         // Ensure that graph.php will allow the user to see the graph.
110         if (has_capability('mod/survey:readresponses', $context) || !$groupmode || groups_is_member($currentgroup)) {
112             echo $OUTPUT->box(get_string("surveycompleted", "survey"));
113             echo $OUTPUT->box(get_string("peoplecompleted", "survey", $numusers));
115             echo '<div class="resultgraph">';
116             survey_print_graph("id=$cm->id&amp;sid=$USER->id&amp;group=$currentgroup&amp;type=student.png");
117             echo '</div>';
118         } else {
119             echo $OUTPUT->box(get_string("surveycompletednograph", "survey"));
120             echo $OUTPUT->box(get_string("peoplecompleted", "survey", $numusers));
121         }
123     } else {
125         echo $OUTPUT->box(format_module_intro('survey', $survey, $cm->id), 'generalbox', 'intro');
126         echo $OUTPUT->spacer(array('height' => 30, 'width' => 1), true);  // Should be done with CSS instead.
128         $questions = $DB->get_records_list("survey_questions", "id", explode(',', $survey->questions));
129         $questionorder = explode(",", $survey->questions);
130         foreach ($questionorder as $key => $val) {
131             $question = $questions[$val];
132             if ($question->type == 0 or $question->type == 1) {
133                 if ($answer = survey_get_user_answer($survey->id, $question->id, $USER->id)) {
134                     $table = new html_table();
135                     $table->head = array(get_string($question->text, "survey"));
136                     $table->align = array ("left");
137                     $table->data[] = array(s($answer->answer1));// No html here, just plain text.
138                     echo html_writer::table($table);
139                     echo $OUTPUT->spacer(array('height' => 30, 'width' => 1), true);
140                 }
141             }
142         }
143     }
145     echo $OUTPUT->footer();
146     exit;
149 // Start the survey form.
150 $params = array(
151     'objectid' => $survey->id,
152     'context' => $context,
153     'courseid' => $course->id,
154     'other' => array('viewed' => 'form')
155 );
156 $event = \mod_survey\event\course_module_viewed::create($params);
157 $event->trigger();
159 echo "<form method=\"post\" action=\"save.php\" id=\"surveyform\">";
160 echo '<div>';
161 echo "<input type=\"hidden\" name=\"id\" value=\"$id\" />";
162 echo "<input type=\"hidden\" name=\"sesskey\" value=\"".sesskey()."\" />";
164 echo $OUTPUT->box(format_module_intro('survey', $survey, $cm->id), 'generalbox boxaligncenter bowidthnormal', 'intro');
165 echo '<div>'. get_string('allquestionrequireanswer', 'survey'). '</div>';
167 // Get all the major questions and their proper order.
168 if (! $questions = $DB->get_records_list("survey_questions", "id", explode(',', $survey->questions))) {
169     print_error('cannotfindquestion', 'survey');
171 $questionorder = explode( ",", $survey->questions);
173 // Cycle through all the questions in order and print them.
175 global $qnum;  // TODO: ugly globals hack for survey_print_*().
176 global $checklist; // TODO: ugly globals hack for survey_print_*().
177 $qnum = 0;
178 $checklist = array();
179 foreach ($questionorder as $key => $val) {
180     $question = $questions["$val"];
181     $question->id = $val;
183     if ($question->type >= 0) {
185         if ($question->text) {
186             $question->text = get_string($question->text, "survey");
187         }
189         if ($question->shorttext) {
190             $question->shorttext = get_string($question->shorttext, "survey");
191         }
193         if ($question->intro) {
194             $question->intro = get_string($question->intro, "survey");
195         }
197         if ($question->options) {
198             $question->options = get_string($question->options, "survey");
199         }
201         if ($question->multi) {
202             survey_print_multi($question);
203         } else {
204             survey_print_single($question);
205         }
206     }
209 if (!is_enrolled($context)) {
210     echo '</div>';
211     echo "</form>";
212     echo $OUTPUT->footer();
213     exit;
216 $checkarray = Array('questions' => Array());
217 if (!empty($checklist)) {
218     foreach ($checklist as $question => $default) {
219         $checkarray['questions'][] = Array('question' => $question, 'default' => $default);
220     }
222 $PAGE->requires->data_for_js('surveycheck', $checkarray);
223 $module = array(
224     'name'      => 'mod_survey',
225     'fullpath'  => '/mod/survey/survey.js',
226     'requires'  => array('yui2-event'),
227 );
228 $PAGE->requires->string_for_js('questionsnotanswered', 'survey');
229 $PAGE->requires->js_init_call('M.mod_survey.init', $checkarray, true, $module);
231 echo '<br />';
232 echo '<input type="submit" value="'.get_string("clicktocontinue", "survey").'" />';
233 echo '</div>';
234 echo "</form>";
236 echo $OUTPUT->footer();