2001-11-22 06:23:56 +00:00
|
|
|
<?PHP // $Id$
|
|
|
|
|
2003-01-05 14:19:20 +00:00
|
|
|
require_once('../../config.php');
|
|
|
|
require_once('lib.php');
|
2001-11-22 06:23:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
// Make sure this is a legitimate posting
|
|
|
|
|
2003-01-05 06:45:20 +00:00
|
|
|
if (!$formdata = data_submitted("$CFG->wwwroot/mod/survey/view.php")) {
|
2001-11-22 06:23:56 +00:00
|
|
|
error("You are not supposed to use this script like that.");
|
|
|
|
}
|
|
|
|
|
2002-06-09 14:14:07 +00:00
|
|
|
if (isguest()) {
|
2003-01-05 06:45:20 +00:00
|
|
|
error("Guests are not allowed to answer surveys", $_SERVER["HTTP_REFERER"]);
|
2002-06-09 14:14:07 +00:00
|
|
|
}
|
|
|
|
|
2001-11-22 06:23:56 +00:00
|
|
|
require_variable($id); // Course Module ID
|
|
|
|
|
|
|
|
if (! $cm = get_record("course_modules", "id", $id)) {
|
|
|
|
error("Course Module ID was incorrect");
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! $course = get_record("course", "id", $cm->course)) {
|
|
|
|
error("Course is misconfigured");
|
|
|
|
}
|
|
|
|
|
|
|
|
require_login($course->id);
|
|
|
|
|
|
|
|
if (! $survey = get_record("survey", "id", $cm->instance)) {
|
|
|
|
error("Survey ID was incorrect");
|
|
|
|
}
|
|
|
|
|
2002-05-31 09:07:11 +00:00
|
|
|
add_to_log($course->id, "survey", "submit", "view.php?id=$cm->id", "$survey->id");
|
2001-11-22 06:23:56 +00:00
|
|
|
|
|
|
|
if (survey_already_done($survey->id, $USER->id)) {
|
2003-01-05 06:45:20 +00:00
|
|
|
notice(get_string("alreadysubmitted", "survey"), $_SERVER["HTTP_REFERER"]);
|
2001-11-22 06:23:56 +00:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Sort through the data and arrange it
|
|
|
|
// This is necessary because some of the questions
|
|
|
|
// may have two answers, eg Question 1 -> 1 and P1
|
|
|
|
|
|
|
|
$answers = array();
|
|
|
|
|
2003-01-05 06:45:20 +00:00
|
|
|
foreach ($formdata as $key => $val) {
|
2001-11-22 06:23:56 +00:00
|
|
|
if ($key <> "userid" && $key <> "id") {
|
|
|
|
if ( substr($key,0,1) == "q") {
|
|
|
|
$key = substr($key,1); // keep everything but the 'q'
|
|
|
|
}
|
|
|
|
if ( substr($key,0,1) == "P") {
|
|
|
|
$realkey = substr($key,1);
|
|
|
|
$answers[$realkey][1] = $val;
|
|
|
|
} else {
|
|
|
|
$answers[$key][0] = $val;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Now store the data.
|
|
|
|
|
|
|
|
$timenow = time();
|
|
|
|
foreach ($answers as $key => $val) {
|
2002-12-23 05:57:05 +00:00
|
|
|
|
|
|
|
$newdata->time = $timenow;
|
2002-12-23 09:39:26 +00:00
|
|
|
$newdata->userid = $USER->id;
|
2002-12-23 05:57:05 +00:00
|
|
|
$newdata->survey = $survey->id;
|
|
|
|
$newdata->question = $key;
|
2003-01-06 14:01:56 +00:00
|
|
|
if (!empty($val[0])) {
|
|
|
|
$newdata->answer1 = $val[0];
|
|
|
|
} else {
|
|
|
|
$newdata->answer1 = "";
|
|
|
|
}
|
|
|
|
if (!empty($val[1])) {
|
|
|
|
$newdata->answer2 = $val[1];
|
|
|
|
} else {
|
|
|
|
$newdata->answer2 = "";
|
|
|
|
}
|
2002-12-23 05:57:05 +00:00
|
|
|
|
|
|
|
if (! insert_record("survey_answers", $newdata)) {
|
2001-11-22 06:23:56 +00:00
|
|
|
error("Encountered a problem trying to store your results. Sorry.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Print the page and finish up.
|
|
|
|
|
2002-08-12 17:54:13 +00:00
|
|
|
$strsurveys = get_string("modulenameplural", "survey");
|
|
|
|
$strsurveysaved = get_string("surveysaved", "survey");
|
|
|
|
|
|
|
|
print_header("$course->shortname: $strsurveysaved", "$course->fullname",
|
2001-11-22 06:23:56 +00:00
|
|
|
"<A HREF=/course/view.php?id=$course->id>$course->shortname</A> ->
|
2002-08-12 17:54:13 +00:00
|
|
|
<A HREF=index.php?id=$course->id>$strsurveys</A> -> $survey->name -> $strsurveysaved", "");
|
2001-11-22 06:23:56 +00:00
|
|
|
|
|
|
|
|
2002-08-12 17:54:13 +00:00
|
|
|
notice(get_string("thanksforanswers","survey", $USER->firstname), "$CFG->wwwroot/course/view.php?id=$course->id");
|
2001-11-22 06:23:56 +00:00
|
|
|
|
|
|
|
exit;
|
|
|
|
|
|
|
|
|
|
|
|
?>
|