. /** * This file is responsible for producing the survey reports * * @package mod_survey * @copyright 1999 onwards Martin Dougiamas {@link http://moodle.com} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ require_once("../../config.php"); require_once("lib.php"); // Check that all the parameters have been provided. $id = required_param('id', PARAM_INT); // Course Module ID $action = optional_param('action', '', PARAM_ALPHA); // What to look at $qid = optional_param('qid', 0, PARAM_RAW); // Question IDs comma-separated list $student = optional_param('student', 0, PARAM_INT); // Student ID $notes = optional_param('notes', '', PARAM_RAW); // Save teachers notes $qids = explode(',', $qid); $qids = clean_param_array($qids, PARAM_INT); $qid = implode (',', $qids); if (! $cm = get_coursemodule_from_id('survey', $id)) { print_error('invalidcoursemodule'); } if (! $course = $DB->get_record("course", array("id"=>$cm->course))) { print_error('coursemisconf'); } $url = new moodle_url('/mod/survey/report.php', array('id'=>$id)); if ($action !== '') { $url->param('action', $action); } if ($qid !== 0) { $url->param('qid', $qid); } if ($student !== 0) { $url->param('student', $student); } if ($notes !== '') { $url->param('notes', $notes); } $PAGE->set_url($url); require_login($course, false, $cm); $context = context_module::instance($cm->id); require_capability('mod/survey:readresponses', $context); if (! $survey = $DB->get_record("survey", array("id"=>$cm->instance))) { print_error('invalidsurveyid', 'survey'); } if (! $template = $DB->get_record("survey", array("id"=>$survey->template))) { print_error('invalidtmptid', 'survey'); } $showscales = ($template->name != 'ciqname'); $strreport = get_string("report", "survey"); $strsurvey = get_string("modulename", "survey"); $strsurveys = get_string("modulenameplural", "survey"); $strsummary = get_string("summary", "survey"); $strscales = get_string("scales", "survey"); $strquestion = get_string("question", "survey"); $strquestions = get_string("questions", "survey"); $strdownload = get_string("download", "survey"); $strallscales = get_string("allscales", "survey"); $strallquestions = get_string("allquestions", "survey"); $strselectedquestions = get_string("selectedquestions", "survey"); $strseemoredetail = get_string("seemoredetail", "survey"); $strnotes = get_string("notes", "survey"); switch ($action) { case 'download': $PAGE->navbar->add(get_string('downloadresults', 'survey')); break; case 'summary': case 'scales': case 'questions': $PAGE->navbar->add($strreport); $PAGE->navbar->add(${'str'.$action}); break; case 'students': $PAGE->navbar->add($strreport); $PAGE->navbar->add(get_string('participants')); break; case '': $PAGE->navbar->add($strreport); $PAGE->navbar->add($strsummary); break; default: $PAGE->navbar->add($strreport); break; } $PAGE->set_title("$course->shortname: ".format_string($survey->name)); $PAGE->set_heading($course->fullname); echo $OUTPUT->header(); echo $OUTPUT->heading($survey->name); /// Check to see if groups are being used in this survey if ($groupmode = groups_get_activity_groupmode($cm)) { // Groups are being used $menuaction = $action == "student" ? "students" : $action; $currentgroup = groups_get_activity_group($cm, true); groups_print_activity_menu($cm, $CFG->wwwroot . "/mod/survey/report.php?id=$cm->id&action=$menuaction&qid=$qid"); } else { $currentgroup = 0; } $params = array( 'objectid' => $survey->id, 'context' => $context, 'courseid' => $course->id, 'relateduserid' => $student, 'other' => array('action' => $action, 'groupid' => $currentgroup) ); $event = \mod_survey\event\report_viewed::create($params); $event->trigger(); if ($currentgroup) { $users = get_users_by_capability($context, 'mod/survey:participate', '', '', '', '', $currentgroup, null, false); } else if (!empty($cm->groupingid)) { $groups = groups_get_all_groups($courseid, 0, $cm->groupingid); $groups = array_keys($groups); $users = get_users_by_capability($context, 'mod/survey:participate', '', '', '', '', $groups, null, false); } else { $users = get_users_by_capability($context, 'mod/survey:participate', '', '', '', '', '', null, false); $group = false; } $groupingid = $cm->groupingid; echo $OUTPUT->box_start("generalbox boxaligncenter"); if ($showscales) { echo "$strsummary"; echo " $strscales"; echo " $strquestions"; echo " ".get_string('participants').""; if (has_capability('mod/survey:download', $context)) { echo " $strdownload"; } if (empty($action)) { $action = "summary"; } } else { echo "$strquestions"; echo " ".get_string('participants').""; if (has_capability('mod/survey:download', $context)) { echo " $strdownload"; } if (empty($action)) { $action = "questions"; } } echo $OUTPUT->box_end(); echo $OUTPUT->spacer(array('height'=>30, 'width'=>30, 'br'=>true)); // should be done with CSS instead /// Print the menu across the top $virtualscales = false; switch ($action) { case "summary": echo $OUTPUT->heading($strsummary, 3); if (survey_count_responses($survey->id, $currentgroup, $groupingid)) { echo "
"; } else { echo $OUTPUT->notification(get_string("nobodyyet","survey")); } break; case "scales": echo $OUTPUT->heading($strscales, 3); if (! $results = survey_get_responses($survey->id, $currentgroup, $groupingid) ) { echo $OUTPUT->notification(get_string("nobodyyet","survey")); } else { $questions = $DB->get_records_list("survey_questions", "id", explode(',', $survey->questions)); $questionorder = explode(",", $survey->questions); foreach ($questionorder as $key => $val) { $question = $questions[$val]; if ($question->type < 0) { // We have some virtual scales. Just show them. $virtualscales = true; break; } } foreach ($questionorder as $key => $val) { $question = $questions[$val]; if ($question->multi) { if (!empty($virtualscales) && $question->type > 0) { // Don't show non-virtual scales if virtual continue; } echo ""; echo "id\">"; survey_print_graph("id=$id&qid=$question->id&group=$currentgroup&type=question.png"); echo "
"; } else { $table = new html_table(); $table->head = array($question->text); $table->align = array ("left"); $contents = ''.fullname($a).' | '; $contents .= ''.s($a->answer1).' | '; $contents .= "
"; echo $OUTPUT->user_picture($user, array('courseid'=>$course->id)); echo "
"; $questions = $DB->get_records_list("survey_questions", "id", explode(',', $survey->questions)); $questionorder = explode(",", $survey->questions); if ($showscales) { // Print overall summary echo ""; survey_print_graph("id=$id&sid=$student&type=student.png"); echo "
"; // Print scales foreach ($questionorder as $key => $val) { $question = $questions[$val]; if ($question->type < 0) { // We have some virtual scales. Just show them. $virtualscales = true; break; } } foreach ($questionorder as $key => $val) { $question = $questions[$val]; if ($question->multi) { if ($virtualscales && $question->type > 0) { // Don't show non-virtual scales if virtual continue; } echo "