You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
209 lines
7.8 KiB
209 lines
7.8 KiB
<?php
|
|
/*
|
|
==============================================================================
|
|
Dokeos - elearning and course management software
|
|
|
|
Copyright (c) 2004-2008 Dokeos SPRL
|
|
|
|
For a full list of contributors, see "credits.txt".
|
|
The full license can be read in "license.txt".
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU General Public License
|
|
as published by the Free Software Foundation; either version 2
|
|
of the License, or (at your option) any later version.
|
|
|
|
See the GNU General Public License for more details.
|
|
|
|
Contact: Dokeos, rue du Corbeau, 108, B-1030 Brussels, Belgium, info@dokeos.com
|
|
==============================================================================
|
|
*/
|
|
|
|
/**
|
|
* @package dokeos.survey
|
|
* @author unknown, the initial survey that did not make it in 1.8 because of bad code
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University: cleanup, refactoring and rewriting large parts of the code
|
|
* @author Julio Montoya Armas <gugli100@gmail.com>, Dokeos: Personality Test modifications
|
|
* @version $Id: survey_list.php 10680 2007-01-11 21:26:23Z pcool $
|
|
*
|
|
* @todo use quickforms for the forms
|
|
*/
|
|
|
|
// name of the language file that needs to be included
|
|
$language_file = 'survey';
|
|
|
|
// including the global dokeos file
|
|
require ('../inc/global.inc.php');
|
|
|
|
// including additional libraries
|
|
//require_once (api_get_path(LIBRARY_PATH)."/survey.lib.php");
|
|
require_once('survey.lib.php');
|
|
|
|
// Database table definitions
|
|
$table_survey = Database :: get_course_table(TABLE_SURVEY);
|
|
$table_survey_question = Database :: get_course_table(TABLE_SURVEY_QUESTION);
|
|
$table_survey_question_option = Database :: get_course_table(TABLE_SURVEY_QUESTION_OPTION);
|
|
$table_course = Database :: get_main_table(TABLE_MAIN_COURSE);
|
|
$table_user = Database :: get_main_table(TABLE_MAIN_USER);
|
|
|
|
// We exit here if ther is no valid $_GET parameter
|
|
if (!isset($_GET['survey_id']) OR !is_numeric($_GET['survey_id'])){
|
|
Display :: display_header(get_lang('SurveyPreview'));
|
|
Display :: display_error_message(get_lang('InvallidSurvey'), false);
|
|
Display :: display_footer();
|
|
exit;
|
|
}
|
|
|
|
|
|
// getting the survey information
|
|
$survey_id = Security::remove_XSS($_GET['survey_id']);
|
|
$survey_data = survey_manager::get_survey($survey_id);
|
|
|
|
if (empty($survey_data)) {
|
|
Display :: display_header(get_lang('SurveyPreview'));
|
|
Display :: display_error_message(get_lang('InvallidSurvey'), false);
|
|
Display :: display_footer();
|
|
exit;
|
|
}
|
|
|
|
$urlname = strip_tags(api_substr(api_html_entity_decode($survey_data['title'],ENT_QUOTES,$charset), 0, 40));
|
|
if (api_strlen(strip_tags($survey_data['title'])) > 40) {
|
|
$urlname .= '...';
|
|
}
|
|
|
|
// breadcrumbs
|
|
$interbreadcrumb[] = array ("url" => 'survey_list.php', 'name' => get_lang('SurveyList'));
|
|
$interbreadcrumb[] = array ("url" => "survey.php?survey_id=".$survey_id, "name" => $urlname);
|
|
|
|
// Header
|
|
Display :: display_header(get_lang('SurveyPreview'));
|
|
|
|
// We exit here is the first or last question is a pagebreak (which causes errors)
|
|
SurveyUtil::check_first_last_question($survey_id, false);
|
|
|
|
// only a course admin is allowed to preview a survey: you are NOT a course admin => error message
|
|
|
|
/*
|
|
if (!api_is_allowed_to_edit(false,true))
|
|
{
|
|
Display :: display_error_message(get_lang('NotAllowed'), false);
|
|
}*/
|
|
// only a course admin is allowed to preview a survey: you are a course admin
|
|
if (api_is_course_admin() || (api_is_course_admin() && $_GET['isStudentView']=='true') || api_is_allowed_to_session_edit(false,true)) {
|
|
// survey information
|
|
echo '<div id="survey_title">'.$survey_data['survey_title'].'</div>';
|
|
echo '<div id="survey_subtitle">'.$survey_data['survey_subtitle'].'</div>';
|
|
|
|
// displaying the survey introduction
|
|
if (!isset($_GET['show']))
|
|
{
|
|
echo '<div id="survey_content" class="survey_content">'.$survey_data['survey_introduction'].'</div>';
|
|
$limit = 0;
|
|
}
|
|
|
|
// displaying the survey thanks message
|
|
if(isset($_POST['finish_survey']))
|
|
{
|
|
echo '<div id="survey_content" class="survey_content"><strong>'.get_lang('SurveyFinished').' </strong>'.$survey_data['survey_thanks'].'</div>';
|
|
Display :: display_footer();
|
|
exit;
|
|
}
|
|
|
|
if (isset($_GET['show']))
|
|
{
|
|
// Getting all the questions for this page and add them to a multidimensional array where the first index is the page.
|
|
// as long as there is no pagebreak fount we keep adding questions to the page
|
|
$questions_displayed = array();
|
|
$paged_questions = array();
|
|
$counter = 0;
|
|
$sql = "SELECT * FROM $table_survey_question
|
|
WHERE survey_id = '".Database::escape_string($survey_id)."'
|
|
ORDER BY sort ASC";
|
|
$result = Database::query($sql, __FILE__, __LINE__);
|
|
|
|
while ($row = Database::fetch_array($result))
|
|
{
|
|
if($row['type'] == 'pagebreak') {
|
|
$counter++;
|
|
} else {
|
|
$paged_questions[$counter][] = $row['question_id'];
|
|
}
|
|
}
|
|
|
|
if (array_key_exists($_GET['show'], $paged_questions))
|
|
{
|
|
$sql = "SELECT survey_question.question_id, survey_question.survey_id, survey_question.survey_question, survey_question.display, survey_question.sort, survey_question.type, survey_question.max_value,
|
|
survey_question_option.question_option_id, survey_question_option.option_text, survey_question_option.sort as option_sort
|
|
FROM $table_survey_question survey_question
|
|
LEFT JOIN $table_survey_question_option survey_question_option
|
|
ON survey_question.question_id = survey_question_option.question_id
|
|
WHERE survey_question.survey_id = '".Database::escape_string($survey_id)."'
|
|
AND survey_question.question_id IN (".Database::escape_string(implode(',',$paged_questions[$_GET['show']])).")
|
|
ORDER BY survey_question.sort, survey_question_option.sort ASC";
|
|
|
|
$result = Database::query($sql, __FILE__, __LINE__);
|
|
$question_counter_max = Database::num_rows($result);
|
|
$counter = 0;
|
|
$limit=0;
|
|
$questions = array();
|
|
while ($row = Database::fetch_array($result))
|
|
{
|
|
// if the type is not a pagebreak we store it in the $questions array
|
|
if($row['type'] <> 'pagebreak')
|
|
{
|
|
$questions[$row['sort']]['question_id'] = $row['question_id'];
|
|
$questions[$row['sort']]['survey_id'] = $row['survey_id'];
|
|
$questions[$row['sort']]['survey_question'] = $row['survey_question'];
|
|
$questions[$row['sort']]['display'] = $row['display'];
|
|
$questions[$row['sort']]['type'] = $row['type'];
|
|
$questions[$row['sort']]['options'][intval($row['option_sort'])] = $row['option_text'];
|
|
$questions[$row['sort']]['maximum_score'] = $row['max_value'];
|
|
}
|
|
// if the type is a pagebreak we are finished loading the questions for this page
|
|
else
|
|
{
|
|
break;
|
|
}
|
|
$counter++;
|
|
}
|
|
}
|
|
}
|
|
// selecting the maximum number of pages
|
|
$sql = "SELECT * FROM $table_survey_question WHERE type='".Database::escape_string('pagebreak')."' AND survey_id='".Database::escape_string($survey_id)."'";
|
|
$result = Database::query($sql, __FILE__, __LINE__);
|
|
$numberofpages = Database::num_rows($result) + 1;
|
|
// Displaying the form with the questions
|
|
if (isset($_GET['show']))
|
|
{
|
|
$show = (int)$_GET['show'] + 1;
|
|
}
|
|
else
|
|
{
|
|
$show = 0;
|
|
}
|
|
echo '<form id="question" name="question" method="post" action="'.api_get_self().'?survey_id='.Security::remove_XSS($survey_id).'&show='.$show.'">';
|
|
if(is_array($questions) && count($questions)>0)
|
|
{
|
|
foreach ($questions as $key=>$question)
|
|
{
|
|
$display = new $question['type'];
|
|
$display->render_question($question);
|
|
}
|
|
}
|
|
if (($show < $numberofpages) OR !$_GET['show'])
|
|
{
|
|
//echo '<a href="'.api_get_self().'?survey_id='.$survey_id.'&show='.$limit.'">NEXT</a>';
|
|
echo '<br /><button type="submit" name="next_survey_page" class="next">'.get_lang('NextQuestion').' </button>';
|
|
}
|
|
if ($show >= $numberofpages AND $_GET['show'])
|
|
{
|
|
echo '<button type="submit" name="finish_survey" class="next">'.get_lang('FinishSurvey').' </button>';
|
|
}
|
|
echo '</form>';
|
|
} else {
|
|
Display :: display_error_message(get_lang('NotAllowed'), false);
|
|
}
|
|
|
|
// Footer
|
|
Display :: display_footer();
|
|
?>
|
|
|