MDL-14493 First checkin of Feedback module into HEAD.
[moodle.git] / mod / feedback / complete_guest.php
1 <?php // $Id$
2 /**
3 * prints the form so an anonymous user can fill out the feedback on the mainsite
4 *
5 * @version $Id$
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");
14     $id = required_param('id', PARAM_INT);
15     $completedid = optional_param('completedid', false, PARAM_INT);
16     $preservevalues  = optional_param('preservevalues', 0,  PARAM_INT);
17     $courseid = optional_param('courseid', false, PARAM_INT);
18     $gopage = optional_param('gopage', -1, PARAM_INT);
19     $lastpage = optional_param('lastpage', false, PARAM_INT);
20     $startitempos = optional_param('startitempos', 0, PARAM_INT);
21     $lastitempos = optional_param('lastitempos', 0, PARAM_INT);
23     $highlightrequired = false;
25     if(($formdata = data_submitted('nomatch')) AND !confirm_sesskey()) {
26         error('no sesskey defined');
27     }
28     
29     //if the use hit enter into a textfield so the form should not submit
30     if(isset($formdata->sesskey) AND !isset($formdata->savevalues) AND !isset($formdata->gonextpage) AND !isset($formdata->gopreviouspage)) {
31         $gopage = $formdata->lastpage;
32     }
33     if(isset($formdata->savevalues)) {
34         $savevalues = true;
35     }else {
36         $savevalues = false;
37     }
38     
39     if($gopage < 0 AND !$savevalues) {
40         if(isset($formdata->gonextpage)){
41             $gopage = $lastpage + 1;
42             $gonextpage = true;
43             $gopreviouspage = false;
44         }else if(isset($formdata->gopreviouspage)){
45             $gopage = $lastpage - 1;
46             $gonextpage = false;
47             $gopreviouspage = true;
48         }else {
49             error('parameter (gopage) required');
50         }
51     }else {
52         $gonextpage = $gopreviouspage = false;
53     }
54     
56     if ($id) {
57         if (! $cm = get_coursemodule_from_id('feedback', $id)) {
58             error("Course Module ID was incorrect");
59         }
60      
61         if (! $course = get_record("course", "id", $cm->course)) {
62             error("Course is misconfigured");
63         }
64      
65         if (! $feedback = get_record("feedback", "id", $cm->instance)) {
66             error("Course module is incorrect");
67         }
68     }
70     $capabilities = feedback_load_capabilities($cm->id);
71     
72     //check whether the feedback is anonymous
73     if($feedback->anonymous == FEEDBACK_ANONYMOUS_YES) {
74         $capabilities->complete = true;
75     }else {
76         error(get_string('feedback_is_not_for_anonymous'));
77     }
78     
79     //check whether the user has a session
80     if(!isset($USER->sesskey) OR !$USER->sesskey) {
81         error('error');
82     }
83     
84     //check whether the feedback is located and! started from the mainsite
85     if($course->id == SITEID AND !$courseid) {
86         $courseid = SITEID;
87     }
88     
89     require_course_login($course);
90     
91     if($courseid AND $courseid != SITEID) {
92         $course2 = get_record('course', 'id', $courseid);
93         require_course_login($course2); //this overwrites the object $course :-(
94         $course = get_record("course", "id", $cm->course); // the workaround
95     }
96     
97     if(!$capabilities->complete) {
98         error(get_string('error'));
99     }
101     
102     /// Print the page header
103     $strfeedbacks = get_string("modulenameplural", "feedback");
104     $strfeedback  = get_string("modulename", "feedback");
105     $buttontext = update_module_button($cm->id, $course->id, $strfeedback);
106     
107     $navlinks = array();
108     $navlinks[] = array('name' => $strfeedbacks, 'link' => "index.php?id=$course->id", 'type' => 'activity');
109     $navlinks[] = array('name' => format_string($feedback->name), 'link' => "", 'type' => 'activityinstance');
110     
111     $navigation = build_navigation($navlinks);
112     
113     print_header_simple(format_string($feedback->name), "",
114                  $navigation, "", "", true, $buttontext, navmenu($course, $cm));
116     //ishidden check. hidden feedbacks except feedbacks on mainsite are only accessible with related capabilities
117     if ((empty($cm->visible) and !$capabilities->viewhiddenactivities) AND $course->id != SITEID) {
118         notice(get_string("activityiscurrentlyhidden"));
119     }
121     feedback_print_errors();
122   
123     //check, if the feedback is open (timeopen, timeclose)
124     $checktime = time();
125     if(($feedback->timeopen > $checktime) OR ($feedback->timeclose < $checktime AND $feedback->timeclose > 0)) {
126         // print_simple_box_start('center');
127         print_box_start('generalbox boxaligncenter');
128             echo '<h2><font color="red">'.get_string('feedback_is_not_open', 'feedback').'</font></h2>';
129             print_continue($CFG->wwwroot.'/course/view.php?id='.$course->id);
130         // print_simple_box_end();
131         print_box_end();
132         print_footer($course);
133         exit;
134     }
135     
136     //additional check for multiple-submit (prevent browsers back-button). the main-check is in view.php
137     $feedback_can_submit = true;
138     if($feedback->multiple_submit == 0 ) {
139         // if($multiple_count = get_record('feedback_tracking', 'userid', $USER->id, 'feedback', $feedback->id)) {
140         if(feedback_is_already_submitted($feedback->id, $courseid)) {
141             $feedback_can_submit = false;
142         }
143     }
144     if($feedback_can_submit) {
145         //preserving the items
146         if($preservevalues == 1){
147             if(!$SESSION->feedback->is_started == true)error('error', $CFG->wwwroot.'/course/view.php?id='.$course->id);
148             //check, if all required items have a value
149             if(feedback_check_values($_POST, $startitempos, $lastitempos)) {
150                 $userid = $USER->id; //arb
151                 if($completedid = feedback_save_guest_values($_POST, $USER->sesskey)){
152                     add_to_log($course->id, "feedback", "startcomplete", "view.php?id=$cm->id", "$feedback->name"); //arb: log even guest submissions or at least the startcomplete since the other add log event is elsewhere
153                     
154                     if(!$gonextpage AND !$gopreviouspage) $preservevalues = false;//es kann gespeichert werden
155                     
156                 }else {
157                     $savereturn = 'failed';
158                     if(isset($lastpage)) {
159                         $gopage = $lastpage;
160                     }else {
161                         error('parameter failed');
162                     }
163                 }
164             }else {
165                 $savereturn = 'missing';
166                 $highlightrequired = true;
167                 if(isset($lastpage)) {
168                     $gopage = $lastpage;
169                 }else {
170                     error('parameter failed');
171                 }
172             }
173         }
174         
175         //saving the items
176         if($savevalues AND !$preservevalues){
177             //exists there any pagebreak, so there are values in the feedback_valuetmp
178             $userid = $USER->id; //arb changed from 0 to $USER->id - no strict anonymous feedbacks - if it is a guest taking it then I want to know that it was a guest (at least in the data saved in the feedback tables)
180             $feedbackcompletedtmp = get_record('feedback_completedtmp', 'id', $completedid);
181             
182             //fake saving for switchrole
183             $is_switchrole = feedback_check_is_switchrole();
184             if($is_switchrole) {
185                 $savereturn = 'saved';
186                 feedback_delete_completedtmp($completedid);
187             }else if($new_completed_id = feedback_save_tmp_values($feedbackcompletedtmp, false, $userid)) {
188                 $savereturn = 'saved';
189                 feedback_email_teachers_anonym($cm, $feedback, $course, $userid);
190                 unset($SESSION->feedback->is_started);
191                 
192             }else {
193                 $savereturn = 'failed';
194             }
195         }
198         if($allbreaks = feedback_get_all_break_positions($feedback->id)){
199             if($gopage <= 0) {
200                 $startposition = 0;
201             }else {
202                 $startposition = $allbreaks[$gopage - 1];
203             }
204             $ispagebreak = true;
205         }else {
206             $startposition = 0;
207             $newpage = 0;
208             $ispagebreak = false;
209         }
210         
211         //get the feedbackitems after the last shown pagebreak
212         $feedbackitems = get_records_select('feedback_item', 'feedback = '.$feedback->id.' AND position > '.$startposition, 'position');
213         //get the first pagebreak
214         if($pagebreaks = get_records_select('feedback_item', "feedback = ".$feedback->id." AND typ = 'pagebreak'", 'position')) {
215             $pagebreaks = array_values($pagebreaks);
216             $firstpagebreak = $pagebreaks[0];
217         }else {
218             $firstpagebreak = false;
219         }
220         $maxitemcount = count_records('feedback_item', 'feedback', $feedback->id);
221         $feedbackcompletedtmp = feedback_get_current_completed($feedback->id, true, $courseid, $USER->sesskey);
223         /// Print the main part of the page
224         ///////////////////////////////////////////////////////////////////////////
225         ///////////////////////////////////////////////////////////////////////////
226         ///////////////////////////////////////////////////////////////////////////
227         print_heading(format_text($feedback->name));
228         
229         if(isset($savereturn) && $savereturn == 'saved') {
230             if($feedback->page_after_submit) {
231                 // print_simple_box_start('center', '75%');
232                 print_box_start('generalbox boxaligncenter boxwidthwide');
233                 echo format_text(stripslashes_safe($feedback->page_after_submit));
234                 // print_simple_box_end();
235                 print_box_end();
236             } else {
237                 echo '<p align="center"><b><font color="green">'.get_string('entries_saved','feedback').'</font></b></p>';
238                 if( intval($feedback->publish_stats) == 1) {
239                     echo '<p align="center"><a href="analysis.php?id=' . $id . '&courseid='.$courseid.'">';
240                     echo get_string('completed_feedbacks', 'feedback').'</a>';
241                     echo '</p>';
242                 }
243             }
244             if($courseid) {
245                 if($courseid == SITEID) {
246                     print_continue($CFG->wwwroot);
247                 }else {
248                     print_continue($CFG->wwwroot.'/course/view.php?id='.$courseid);
249                 }
250             }else {
251                 if($course->id == SITEID) {
252                     print_continue($CFG->wwwroot);
253                 } else {
254                     print_continue($CFG->wwwroot.'/course/view.php?id='.$course->id);
255                 }
256             }
257         }else {
258             if(isset($savereturn) && $savereturn == 'failed') {
259                 echo '<p align="center"><b><font color="red">'.get_string('saving_failed','feedback').'</font></b></p>';
260             }
261     
262             if(isset($savereturn) && $savereturn == 'missing') {
263                 echo '<p align="center"><b><font color="red">'.get_string('saving_failed_because_missing_or_false_values','feedback').'</font></b></p>';
264             }
265     
266             //print the items
267             if(is_array($feedbackitems)){
268                 // print_simple_box_start('center', '75%');
269                 print_box_start('generalbox boxaligncenter boxwidthwide');
270                 echo '<div align="center"><form name="frm" action="'.$ME.'" method="post" onsubmit=" ">';
271                 echo '<table>';
272                 echo '<tr><td colspan="3" align="center">
273                         <input type="hidden" name="anonymous" value="0" />
274                         <input type="hidden" name="anonymous_response" value="'.FEEDBACK_ANONYMOUS_YES.'" />
275                         &nbsp;
276                       </td></tr>';
277                 //check, if there exists required-elements
278                 $countreq = count_records('feedback_item', 'feedback', $feedback->id, 'required', 1);
279                 if($countreq > 0) {
280                     echo '<tr><td colspan="3"><font color="red">(*)' . get_string('items_are_required', 'feedback') . '</font></td></tr>';
281                 }
282                 
283                 unset($startitem);
284                 $itemnr = count_records_select('feedback_item', 'feedback = '. $feedback->id . ' AND hasvalue = 1 AND position < '.$startposition);
285                 foreach($feedbackitems as $feedbackitem){
286                     if(!isset($startitem)) {
287                         //avoid showing double pagebreaks
288                         if($feedbackitem->typ == 'pagebreak') continue;
289                         $startitem = $feedbackitem;
290                     }
291                     $value = '';
292                     //get the value
293                     $frmvaluename = $feedbackitem->typ . '_'. $feedbackitem->id;
294                     if(isset($savereturn)) {
295                         $value =  isset($formdata->{$frmvaluename})?$formdata->{$frmvaluename}:NULL;
296                     }else {
297                         if(isset($feedbackcompletedtmp->id)) {
298                             $value = feedback_get_item_value($feedbackcompletedtmp->id, $feedbackitem->id, $USER->sesskey);
299                         }
300                     }
301                     echo '<tr>';
302                     if($feedbackitem->hasvalue == 1) {
303                         $itemnr++;
304                         echo '<td valign="top">' . $itemnr . '.)&nbsp;</td>';
305                     } else {
306                         echo '<td>&nbsp;</td>';
307                     }
308                     if($feedbackitem->typ != 'pagebreak') {
309                         feedback_print_item($feedbackitem, $value, false, false, $highlightrequired);
310                     }
311                     echo '</tr>';
312                     echo '<tr><td>&nbsp;</td></tr>';
313                     
314                     $lastbreakposition = $feedbackitem->position; //last item-pos (item or pagebreak)
315                     if($feedbackitem->typ == 'pagebreak'){
316                         break;
317                     }else {
318                         $lastitem = $feedbackitem;
319                     }
320                 }
321                 echo '</table>';
322                 echo '<input type="hidden" name="id" value="'.$id.'" />';
323                 echo '<input type="hidden" name="feedbackid" value="'.$feedback->id.'" />';
324                 echo '<input type="hidden" name="lastpage" value="'.$gopage.'" />';
325                 echo '<input type="hidden" name="completedid" value="'.(isset($feedbackcompletedtmp->id)?$feedbackcompletedtmp->id:'').'" />';
326                 echo '<input type="hidden" name="courseid" value="'. $courseid . '" />';
327                 echo '<input type="hidden" name="preservevalues" value="1" />';
328                 if(isset($startitem)) {
329                     echo '<input type="hidden" name="startitempos" value="'. $startitem->position . '" />';
330                     echo '<input type="hidden" name="lastitempos" value="'. $lastitem->position . '" />';
331                 }
332                 
333                 if($ispagebreak AND $lastbreakposition > $firstpagebreak->position) {
334                     echo '<input name="gopreviouspage" type="submit" value="'.get_string('previous_page','feedback').'" />';
335                 }
336                 if($lastbreakposition < $maxitemcount){
337                     echo '<input name="gonextpage" type="submit" value="'.get_string('next_page','feedback').'" />';
338                 }
339                 if($lastbreakposition >= $maxitemcount) { //last page
340                     echo '<input name="savevalues" type="submit" value="'.get_string('save_entries','feedback').'" />';
341                 }
342                 
343                 echo '</form>';
344                 
345                 if($courseid) {
346                     echo '<form name="frm" action="'.$CFG->wwwroot.'/course/view.php?id='.$courseid.'" method="post" onsubmit=" ">';
347                 }else{
348                     if($course->id == SITEID) {
349                         echo '<form name="frm" action="'.$CFG->wwwroot.'" method="post" onsubmit=" ">';
350                     } else {
351                         echo '<form name="frm" action="'.$CFG->wwwroot.'/course/view.php?id='.$course->id.'" method="post" onsubmit=" ">';
352                     }
353                 }
354                 echo '<input type="hidden" name="sesskey" value="' . $USER->sesskey . '" />';
355                 echo '<input type="hidden" name="courseid" value="'. $courseid . '" />';
356                 echo '<button type="submit">'.get_string('cancel').'</button>';
357                 echo '</form>';
358                 echo '</div>';
359                 $SESSION->feedback->is_started = true;
360                 // print_simple_box_end();
361                 print_box_end();
362             }
363         }
364     }else {
365         // print_simple_box_start('center');
366         print_box_start('generalbox boxaligncenter');
367             echo '<h2><font color="red">'.get_string('this_feedback_is_already_submitted', 'feedback').'</font></h2>';
368             print_continue($CFG->wwwroot.'/course/view.php?id='.$course->id);
369         // print_simple_box_end();
370         print_box_end();
371     }
372     /// Finish the page
373     ///////////////////////////////////////////////////////////////////////////
374     ///////////////////////////////////////////////////////////////////////////
375     ///////////////////////////////////////////////////////////////////////////
377     print_footer($course);
379 ?>