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.
1780 lines
62 KiB
1780 lines
62 KiB
<?php
|
|
$config['survey']['debug'] = false;
|
|
/*
|
|
DOKEOS - elearning and course management software
|
|
|
|
For a full list of contributors, see documentation/credits.html
|
|
|
|
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 "documentation/licence.html" more details.
|
|
|
|
Contact:
|
|
Dokeos
|
|
Rue des Palais 44 Paleizenstraat
|
|
B-1030 Brussels - Belgium
|
|
Tel. +32 (2) 211 34 56
|
|
*/
|
|
|
|
/**
|
|
* @package dokeos.survey
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University: cleanup, refactoring and rewriting large parts (if not all) of the code
|
|
* @version $Id: survey.lib.php 10680 2007-01-11 21:26:23Z pcool $
|
|
*
|
|
* @todo move this file to inc/lib
|
|
* @todo use consistent naming for the functions (save vs store for instance)
|
|
*/
|
|
|
|
class survey_manager
|
|
{
|
|
|
|
/******************************************************************************************************
|
|
SURVEY FUNCTIONS
|
|
*****************************************************************************************************/
|
|
|
|
/**
|
|
* This function retrieves all the survey information
|
|
*
|
|
* @param integer $survey_id the id of the survey
|
|
* @param boolean $shared this parameter determines if we have to get the information of a survey from the central (shared) database or from the
|
|
* course database
|
|
*
|
|
* @return array
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version February 2007
|
|
*
|
|
* @todo this is the same function as in create_new_survey.php
|
|
*/
|
|
function get_survey($survey_id,$shared=0)
|
|
{
|
|
global $_course;
|
|
|
|
// table definition
|
|
$table_survey = Database :: get_course_table(TABLE_SURVEY, $_course['db_name']);
|
|
if ($shared<>0)
|
|
{
|
|
$table_survey = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY_QUESTION);
|
|
}
|
|
|
|
$sql = "SELECT * FROM $table_survey WHERE survey_id='".Database::escape_string($survey_id)."'";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$return = Database::fetch_array($result,'ASSOC');
|
|
|
|
// we do this (temporarily) to have the array match the quickform elements immediately
|
|
// idealiter the fields in the db match the quickform fields
|
|
$return['survey_code'] = $return['code'];
|
|
$return['survey_title'] = $return['title'];
|
|
$return['survey_subtitle'] = $return['subtitle'];
|
|
$return['survey_language'] = $return['lang'];
|
|
$return['start_date'] = $return['avail_from'];
|
|
$return['end_date'] = $return['avail_till'];
|
|
$return['survey_share'] = $return['is_shared'];
|
|
$return['survey_introduction'] = $return['intro'];
|
|
$return['survey_thanks'] = $return['surveythanks'];
|
|
return $return;
|
|
}
|
|
|
|
/**
|
|
* This function stores a survey in the database.
|
|
*
|
|
* @param array $values
|
|
* @return array $return the type of return message that has to be displayed and the message in it
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version February 2007
|
|
*/
|
|
function store_survey($values)
|
|
{
|
|
global $_user;
|
|
|
|
// table defnitions
|
|
$table_survey = Database :: get_course_table(TABLE_SURVEY);
|
|
|
|
if ($values['survey_share']['survey_share'] !== '0')
|
|
{
|
|
$shared_survey_id = survey_manager::store_shared_survey($values);
|
|
}
|
|
|
|
if (!$values['survey_id'] OR !is_numeric($values['survey_id']))
|
|
{
|
|
if ($values['anonymous']=='')
|
|
{
|
|
$values['anonymous']=0;
|
|
}
|
|
$sql = "INSERT INTO $table_survey (code, title, subtitle, author, lang, avail_from, avail_till, is_shared, template, intro, surveythanks, creation_date, anonymous) VALUES (
|
|
'".Database::escape_string($values['survey_code'])."',
|
|
'".Database::escape_string($values['survey_title'])."',
|
|
'".Database::escape_string($values['survey_subtitle'])."',
|
|
'".Database::escape_string($_user['user_id'])."',
|
|
'".Database::escape_string($values['survey_language'])."',
|
|
'".Database::escape_string($values['start_date'])."',
|
|
'".Database::escape_string($values['end_date'])."',
|
|
'".Database::escape_string($shared_survey_id)."',
|
|
'".Database::escape_string('template')."',
|
|
'".Database::escape_string($values['survey_introduction'])."',
|
|
'".Database::escape_string($values['survey_thanks'])."',
|
|
'".date('Y-m-d H:i:s')."',
|
|
'".Database::escape_string($values['anonymous'])."'
|
|
)";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$survey_id = Database::insert_id();
|
|
|
|
//$return['message'] = get_lang('SurveyCreatedSuccesfully').'<br />'.get_lang('YouCanNowAddQuestionToYourSurvey').': ';
|
|
//$return['message'] .= '<a href="survey.php?survey_id='.$survey_id.'">'.get_lang('ClickHere').'</a>';
|
|
$return['message'] = 'SurveyCreatedSuccesfully';
|
|
$return['type'] = 'confirmation';
|
|
$return['id'] = $survey_id;
|
|
}
|
|
else
|
|
{
|
|
if ($values['anonymous']=='')
|
|
{
|
|
$values['anonymous']=0;
|
|
}
|
|
$sql = "UPDATE $table_survey SET
|
|
code = '".Database::escape_string($values['survey_code'])."',
|
|
title = '".Database::escape_string($values['survey_title'])."',
|
|
subtitle = '".Database::escape_string($values['survey_subtitle'])."',
|
|
author = '".Database::escape_string($_user['user_id'])."',
|
|
lang = '".Database::escape_string($values['survey_language'])."',
|
|
avail_from = '".Database::escape_string($values['start_date'])."',
|
|
avail_till = '".Database::escape_string($values['end_date'])."',
|
|
is_shared = '".Database::escape_string($shared_survey_id)."',
|
|
template = '".Database::escape_string('template')."',
|
|
intro = '".Database::escape_string($values['survey_introduction'])."',
|
|
surveythanks = '".Database::escape_string($values['survey_thanks'])."',
|
|
anonymous = '".Database::escape_string($values['anonymous'])."'
|
|
WHERE survey_id = '".Database::escape_string($values['survey_id'])."'";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
//$return['message'] = get_lang('SurveyUpdatedSuccesfully').'<br />'.get_lang('YouCanNowAddQuestionToYourSurvey').': ';
|
|
//$return['message'] .= '<a href="survey.php?survey_id='.$values['survey_id'].'">'.get_lang('Here').'</a>';
|
|
//$return['message'] .= get_lang('OrReturnToSurveyOverview').'<a href="survey_list.php">'.get_lang('Here').'</a>';
|
|
$return['message'] = 'SurveyUpdatedSuccesfully';
|
|
$return['type'] = 'confirmation';
|
|
$return['id'] = $values['survey_id'];
|
|
}
|
|
|
|
return $return;
|
|
}
|
|
|
|
/**
|
|
* This function stores a shared survey in the central database.
|
|
*
|
|
* @param array $values
|
|
* @return array $return the type of return message that has to be displayed and the message in it
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version February 2007
|
|
*/
|
|
function store_shared_survey($values)
|
|
{
|
|
global $_user;
|
|
global $_course;
|
|
|
|
// table defnitions
|
|
$table_survey = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY);
|
|
|
|
if (!$values['survey_id'] OR !is_numeric($values['survey_id']) OR $values['survey_share']['survey_share'] == 'true')
|
|
{
|
|
$sql = "INSERT INTO $table_survey (code, title, subtitle, author, lang, template, intro, surveythanks, creation_date, course_code) VALUES (
|
|
'".Database::escape_string($values['survey_code'])."',
|
|
'".Database::escape_string($values['survey_title'])."',
|
|
'".Database::escape_string($values['survey_subtitle'])."',
|
|
'".Database::escape_string($_user['user_id'])."',
|
|
'".Database::escape_string($values['survey_language'])."',
|
|
'".Database::escape_string('template')."',
|
|
'".Database::escape_string($values['survey_introduction'])."',
|
|
'".Database::escape_string($values['survey_thanks'])."',
|
|
'".date('Y-m-d H:i:s')."',
|
|
'".$_course['id']."')";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$return = Database::insert_id();
|
|
}
|
|
else
|
|
{
|
|
$sql = "UPDATE $table_survey SET
|
|
code = '".Database::escape_string($values['survey_code'])."',
|
|
title = '".Database::escape_string($values['survey_title'])."',
|
|
subtitle = '".Database::escape_string($values['survey_subtitle'])."',
|
|
author = '".Database::escape_string($_user['user_id'])."',
|
|
lang = '".Database::escape_string($values['survey_language'])."',
|
|
template = '".Database::escape_string('template')."',
|
|
intro = '".Database::escape_string($values['survey_introduction'])."',
|
|
surveythanks = '".Database::escape_string($values['survey_thanks'])."'
|
|
WHERE survey_id = '".Database::escape_string($values['survey_share']['survey_share'])."'";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$return = $values['survey_share']['survey_share'];
|
|
}
|
|
return $return;
|
|
}
|
|
|
|
/**
|
|
* This function deletes a survey (and also all the question in that survey
|
|
*
|
|
* @param $survey_id the id of the survey that has to be deleted
|
|
* @return true
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function delete_survey($survey_id, $shared=false)
|
|
{
|
|
// Database table definitions
|
|
$table_survey = Database :: get_course_table(TABLE_SURVEY);
|
|
if ($shared)
|
|
{
|
|
$table_survey = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY);
|
|
}
|
|
|
|
// deleting the survey
|
|
$sql = "DELETE from $table_survey WHERE survey_id='".Database::escape_string($survey_id)."'";
|
|
$res = api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
// deleting the questions of the survey
|
|
survey_manager::delete_all_survey_questions($survey_id, $shared);
|
|
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* This function duplicates a survey (and also all the question in that survey
|
|
*
|
|
* @param $survey_id the id of the survey that has to be duplicated
|
|
* @return true
|
|
*
|
|
* @author Eric Marguin <e.marguin@elixir-interactive.com>, Elixir Interactive
|
|
* @version October 2007
|
|
*/
|
|
function empty_survey($survey_id)
|
|
{
|
|
// Database table definitions
|
|
$table_survey_invitation = Database :: get_course_table(TABLE_SURVEY_INVITATION);
|
|
$table_survey_answer = Database :: get_course_table(TABLE_SURVEY_ANSWER);
|
|
$table_survey = Database :: get_course_table(TABLE_SURVEY);
|
|
|
|
$datas = survey_manager::get_survey($survey_id);
|
|
|
|
$sql = 'DELETE FROM '.$table_survey_invitation.' WHERE survey_code = "'.Database::escape_string($datas['code']).'"';
|
|
api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
$sql = 'DELETE FROM '.$table_survey_answer.' WHERE survey_id='.intval($survey_id);
|
|
api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
$sql = 'UPDATE '.$table_survey.' SET invited=0, answered=0 WHERE survey_id='.intval($survey_id);
|
|
api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* This function recalculates the number of people who have taken the survey (=filled at least one question)
|
|
*
|
|
* @param $survey_id the id of the survey somebody
|
|
* @return true
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version February 2007
|
|
*/
|
|
function update_survey_answered($survey_id, $user, $survey_code)
|
|
{
|
|
global $_course;
|
|
|
|
// Database table definitions
|
|
$table_survey = Database :: get_course_table(TABLE_SURVEY, $_course['db_name']);
|
|
$table_survey_invitation = Database :: get_course_table(TABLE_SURVEY_INVITATION, $_course['db_name']);
|
|
|
|
// getting a list with all the people who have filled the survey
|
|
$people_filled = survey_manager::get_people_who_filled_survey($survey_id);
|
|
$number = count($people_filled);
|
|
|
|
// storing this value in the survey table
|
|
$sql = "UPDATE $table_survey SET answered = '".Database::escape_string($number)."' WHERE survey_id = '".Database::escape_string($survey_id)."'";
|
|
$res = api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
// storing that the user has finished the survey.
|
|
$sql = "UPDATE $table_survey_invitation SET answered='1' WHERE user='".Database::escape_string($user)."' AND survey_code='".Database::escape_string($survey_code)."'";
|
|
$res = api_sql_query($sql, __FILE__, __LINE__);
|
|
}
|
|
|
|
/**
|
|
* This function gets a complete structure of a survey (all survey information, all question information
|
|
* of all the questions and all the options of all the questions.
|
|
*
|
|
* @param integer $survey_id the id of the survey
|
|
* @param boolean $shared this parameter determines if we have to get the information of a survey from the central (shared) database or from the
|
|
* course database
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version February 2007
|
|
*/
|
|
function get_complete_survey_structure($survey_id, $shared=0)
|
|
{
|
|
// 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);
|
|
|
|
if ($shared<>0)
|
|
{
|
|
$table_survey = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY_QUESTION);
|
|
$table_survey_question = Database :: get_course_table(TABLE_SHARED_SURVEY_QUESTION);
|
|
$table_survey_question_option = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY_QUESTION_OPTION);
|
|
}
|
|
|
|
$structure = survey_manager::get_survey($survey_id, $shared);
|
|
|
|
$structure['questions'] = survey_manager::get_questions($survey_id);
|
|
}
|
|
|
|
/******************************************************************************************************
|
|
SURVEY QUESTION FUNCTIONS
|
|
*****************************************************************************************************/
|
|
|
|
/**
|
|
* This function return the "icon" of the question type
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version February 2007
|
|
*/
|
|
function icon_question($type)
|
|
{
|
|
// the possible question types
|
|
$possible_types = array('yesno', 'multiplechoice', 'multipleresponse', 'open', 'dropdown', 'comment', 'pagebreak', 'percentage', 'score');
|
|
|
|
// the images array
|
|
$icon_question = array(
|
|
'yesno' => 'yesno.gif',
|
|
'multiplechoice' => 'mcua.gif',
|
|
'multipleresponse' => 'mcma.gif',
|
|
'open' => 'open_answer.gif',
|
|
'dropdown' => 'dropdown.gif',
|
|
'percentage' => 'percentagequestion.gif',
|
|
'score' => 'scorequestion.gif',
|
|
'comment' => 'commentquestion.gif',
|
|
'pagebreak' => 'page_end.gif',
|
|
);
|
|
|
|
if (in_array($type, $possible_types))
|
|
{
|
|
return $icon_question[$type];
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* This function retrieves all the information of a question
|
|
*
|
|
* @param integer $question_id the id of the question
|
|
* @return array
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*
|
|
* @todo one sql call should do the trick
|
|
*/
|
|
function get_question($question_id, $shared=false)
|
|
{
|
|
// table definitions
|
|
$tbl_survey_question = Database :: get_course_table(TABLE_SURVEY_QUESTION);
|
|
$table_survey_question_option = Database :: get_course_table(TABLE_SURVEY_QUESTION_OPTION);
|
|
if ($shared)
|
|
{
|
|
$tbl_survey_question = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY_QUESTION);
|
|
$table_survey_question_option = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY_QUESTION_OPTION);
|
|
}
|
|
|
|
// getting the information of the question
|
|
$sql = "SELECT * FROM $tbl_survey_question WHERE question_id='".Database::escape_string($question_id)."' ORDER BY `sort`";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$row = Database::fetch_array($result,'ASSOC');
|
|
$return['survey_id'] = $row['survey_id'];
|
|
$return['question_id'] = $row['question_id'];
|
|
$return['type'] = $row['type'];
|
|
$return['question'] = $row['survey_question'];
|
|
$return['horizontalvertical'] = $row['display'];
|
|
$return['shared_question_id'] = $row['shared_question_id'];
|
|
$return['maximum_score'] = $row['max_value'];
|
|
|
|
// getting the information of the question options
|
|
$sql = "SELECT * FROM $table_survey_question_option WHERE question_id='".Database::escape_string($question_id)."' ORDER BY `sort` ";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
while ($row = Database::fetch_array($result,'ASSOC'))
|
|
{
|
|
/** @todo this should be renamed to options instead of answers */
|
|
$return['answers'][] = $row['option_text'];
|
|
/** @todo this can be done more elegantly (used in reporting) */
|
|
$return['answersid'][] = $row['question_option_id'];
|
|
}
|
|
return $return;
|
|
}
|
|
|
|
|
|
/**
|
|
* This function gets all the question of any given survey
|
|
*
|
|
* @param integer $survey_id the id of the survey
|
|
* @return array containing all the questions of the survey
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version February 2007
|
|
*
|
|
* @todo one sql call should do the trick
|
|
*/
|
|
function get_questions($survey_id)
|
|
{
|
|
// table definitions
|
|
$tbl_survey_question = Database :: get_course_table(TABLE_SURVEY_QUESTION);
|
|
$table_survey_question_option = Database :: get_course_table(TABLE_SURVEY_QUESTION_OPTION);
|
|
|
|
// getting the information of the question
|
|
$sql = "SELECT * FROM $tbl_survey_question WHERE survey_id='".Database::escape_string($survey_id)."'";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
while ($row = Database::fetch_array($result,'ASSOC'))
|
|
{
|
|
$return[$row['question_id']]['survey_id'] = $row['survey_id'];
|
|
$return[$row['question_id']]['question_id'] = $row['question_id'];
|
|
$return[$row['question_id']]['type'] = $row['type'];
|
|
$return[$row['question_id']]['question'] = $row['survey_question'];
|
|
$return[$row['question_id']]['horizontalvertical'] = $row['display'];
|
|
$return[$row['question_id']]['maximum_score'] = $row['max_value'];
|
|
$return[$row['question_id']]['sort'] = $row['sort'];
|
|
|
|
}
|
|
|
|
// getting the information of the question options
|
|
$sql = "SELECT * FROM $table_survey_question_option WHERE survey_id='".Database::escape_string($survey_id)."'";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
while ($row = Database::fetch_array($result,'ASSOC'))
|
|
{
|
|
$return[$row['question_id']]['answers'][] = $row['option_text'];
|
|
}
|
|
return $return;
|
|
}
|
|
|
|
/**
|
|
* This function saves a question in the database.
|
|
* This can be either an update of an existing survey or storing a new survey
|
|
*
|
|
* @param array $form_content all the information of the form
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function save_question($form_content)
|
|
{
|
|
global $_course;
|
|
|
|
// table definitions
|
|
$table_survey = Database :: get_course_table(TABLE_SURVEY, $_course['db_name']);
|
|
$tbl_survey_question = Database :: get_course_table(TABLE_SURVEY_QUESTION, $_course['db_name']);
|
|
|
|
// getting all the information of the survey
|
|
$survey_data = survey_manager::get_survey($form_content['survey_id']);
|
|
|
|
// storing the question in the shared database
|
|
if (is_numeric($survey_data['survey_share']) AND $survey_data['survey_share'] <> 0)
|
|
{
|
|
$shared_question_id = survey_manager::save_shared_question($form_content, $survey_data);
|
|
$form_content['shared_question_id'] = $shared_question_id;
|
|
}
|
|
|
|
// storing a new question
|
|
if ($form_content['question_id'] == '' OR !is_numeric($form_content['question_id']))
|
|
{
|
|
// finding the max sort order of the questions in the given survey
|
|
$sql = "SELECT max(sort) AS max_sort FROM $tbl_survey_question WHERE survey_id='".Database::escape_string($form_content['survey_id'])."'";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$row = Database::fetch_array($result,'ASSOC');
|
|
$max_sort = $row['max_sort'];
|
|
|
|
// adding the question to the survey_question table
|
|
$sql = "INSERT INTO $tbl_survey_question (survey_id,survey_question,survey_question_comment,type,display, sort, shared_question_id, max_value) VALUES (
|
|
'".Database::escape_string($form_content['survey_id'])."',
|
|
'".Database::escape_string($form_content['question'])."',
|
|
'".Database::escape_string($form_content['question_comment'])."',
|
|
'".Database::escape_string($form_content['type'])."',
|
|
'".Database::escape_string($form_content['horizontalvertical'])."',
|
|
'".Database::escape_string($max_sort+1)."',
|
|
'".Database::escape_string($form_content['shared_question_id'])."',
|
|
'".Database::escape_string($form_content['maximum_score'])."'
|
|
)";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$question_id = Database::insert_id();
|
|
$form_content['question_id'] = $question_id;
|
|
$return_message = 'QuestionAdded';
|
|
}
|
|
// updating an existing question
|
|
else
|
|
{
|
|
// adding the question to the survey_question table
|
|
$sql = "UPDATE $tbl_survey_question SET
|
|
survey_question = '".Database::escape_string($form_content['question'])."',
|
|
survey_question_comment = '".Database::escape_string($form_content['question_comment'])."',
|
|
display = '".Database::escape_string($form_content['horizontalvertical'])."',
|
|
max_value = '".Database::escape_string($form_content['maximum_score'])."'
|
|
WHERE question_id = '".Database::escape_string($form_content['question_id'])."'";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$return_message = 'QuestionUpdated';
|
|
}
|
|
// storing the options of the question
|
|
survey_manager::save_question_options($form_content, $survey_data);
|
|
return $return_message;
|
|
}
|
|
|
|
/**
|
|
* This function saves the question in the shared database
|
|
*
|
|
* @param array $form_content all the information of the form
|
|
* @param array $survey_data all the information of the survey
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version February 2007
|
|
*
|
|
* @todo editing of a shared question
|
|
*/
|
|
function save_shared_question($form_content, $survey_data)
|
|
{
|
|
global $_course;
|
|
|
|
// table definitions
|
|
$tbl_survey_question = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY_QUESTION);
|
|
|
|
// storing a new question
|
|
if ($form_content['shared_question_id'] == '' OR !is_numeric($form_content['shared_question_id']))
|
|
{
|
|
// finding the max sort order of the questions in the given survey
|
|
$sql = "SELECT max(sort) AS max_sort FROM $tbl_survey_question
|
|
WHERE survey_id='".Database::escape_string($survey_data['survey_share'])."'
|
|
AND code='".Database::escape_string($_course['id'])."'";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$row = Database::fetch_array($result,'ASSOC');
|
|
$max_sort = $row['max_sort'];
|
|
|
|
// adding the question to the survey_question table
|
|
$sql = "INSERT INTO $tbl_survey_question (survey_id, survey_question, survey_question_comment, type, display, sort, code) VALUES (
|
|
'".Database::escape_string($survey_data['survey_share'])."',
|
|
'".Database::escape_string($form_content['question'])."',
|
|
'".Database::escape_string($form_content['question_comment'])."',
|
|
'".Database::escape_string($form_content['type'])."',
|
|
'".Database::escape_string($form_content['horizontalvertical'])."',
|
|
'".Database::escape_string($max_sort+1)."',
|
|
'".Database::escape_string($_course['id'])."')";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$shared_question_id = Database::insert_id();
|
|
}
|
|
// updating an existing question
|
|
else
|
|
{
|
|
// adding the question to the survey_question table
|
|
$sql = "UPDATE $tbl_survey_question SET
|
|
survey_question = '".Database::escape_string($form_content['question'])."',
|
|
survey_question_comment = '".Database::escape_string($form_content['question_comment'])."',
|
|
display = '".Database::escape_string($form_content['horizontalvertical'])."'
|
|
WHERE question_id = '".Database::escape_string($form_content['shared_question_id'])."'
|
|
AND code='".Database::escape_string($_course['id'])."'";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$shared_question_id = $form_content['shared_question_id'];
|
|
}
|
|
|
|
return $shared_question_id;
|
|
}
|
|
|
|
/**
|
|
* This functions moves a question of a survey up or down
|
|
*
|
|
* @param string $direction
|
|
* @param integer $survey_question_id
|
|
* @param integer $survey_id
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function move_survey_question($direction, $survey_question_id, $survey_id)
|
|
{
|
|
// table definition
|
|
$table_survey_question = Database :: get_course_table(TABLE_SURVEY_QUESTION);
|
|
|
|
if ($direction == 'moveup')
|
|
{
|
|
$sort = 'DESC';
|
|
}
|
|
if ($direction == 'movedown')
|
|
{
|
|
$sort = 'ASC';
|
|
}
|
|
|
|
// finding the two questions that needs to be swapped
|
|
$sql = "SELECT * FROM $table_survey_question WHERE survey_id='".Database::escape_string($survey_id)."' ORDER BY sort $sort";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$found = false;
|
|
while ($row = Database::fetch_array($result,'ASSOC'))
|
|
{
|
|
if ($found == true)
|
|
{
|
|
$question_id_two = $row['question_id'];
|
|
$question_sort_two = $row['sort'];
|
|
$found = false;
|
|
}
|
|
if ($row['question_id'] == $survey_question_id)
|
|
{
|
|
$found = true;
|
|
$question_id_one = $row['question_id'];
|
|
$question_sort_one = $row['sort'];
|
|
}
|
|
}
|
|
|
|
$sql1 = "UPDATE $table_survey_question SET sort = '".Database::escape_string($question_sort_two)."' WHERE question_id='".Database::escape_string($question_id_one)."'";
|
|
$result = api_sql_query($sql1, __FILE__, __LINE__);
|
|
$sql2 = "UPDATE $table_survey_question SET sort = '".Database::escape_string($question_sort_one)."' WHERE question_id='".Database::escape_string($question_id_two)."'";
|
|
$result = api_sql_query($sql2, __FILE__, __LINE__);
|
|
}
|
|
|
|
|
|
/**
|
|
* This function deletes all the questions of a given survey
|
|
* This function is normally only called when a survey is deleted
|
|
*
|
|
* @param $survey_id the id of the survey that has to be deleted
|
|
* @return true
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function delete_all_survey_questions($survey_id, $shared=false)
|
|
{
|
|
// table definitions
|
|
$table_survey_question = Database :: get_course_table(TABLE_SURVEY_QUESTION);
|
|
if ($shared)
|
|
{
|
|
$table_survey_question = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY_QUESTION);
|
|
}
|
|
|
|
// deleting the survey questions
|
|
$sql = "DELETE from $table_survey_question WHERE survey_id='".Database::escape_string($survey_id)."'";
|
|
$res = api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
// deleting all the options of the questions of the survey
|
|
survey_manager::delete_all_survey_questions_options($survey_id, $shared);
|
|
|
|
// deleting all the answers on this survey
|
|
survey_manager::delete_all_survey_answers($survey_id);
|
|
}
|
|
|
|
|
|
/**
|
|
* This function deletes a survey question and all its options
|
|
*
|
|
* @param integer $survey_id the id of the survey
|
|
* @param integer $question_id the id of the question
|
|
* @param integer $shared
|
|
*
|
|
* @todo also delete the answers to this question
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version March 2007
|
|
*/
|
|
function delete_survey_question($survey_id, $question_id, $shared=false)
|
|
{
|
|
// table definitions
|
|
$table_survey_question = Database :: get_course_table(TABLE_SURVEY_QUESTION);
|
|
if ($shared)
|
|
{
|
|
survey_manager::delete_shared_survey_question($survey_id, $question_id);
|
|
}
|
|
|
|
// deleting the survey questions
|
|
$sql = "DELETE from $table_survey_question WHERE survey_id='".Database::escape_string($survey_id)."' AND question_id='".Database::escape_string($question_id)."'";
|
|
$res = api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
// deleting the options of the question of the survey
|
|
survey_manager::delete_survey_question_option($survey_id, $question_id, $shared);
|
|
}
|
|
|
|
/**
|
|
* This function deletes a shared survey question from the main database and all its options
|
|
*
|
|
* @param integer $question_id the id of the question
|
|
* @param integer $shared
|
|
*
|
|
* @todo delete all the options of this question
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version March 2007
|
|
*/
|
|
function delete_shared_survey_question($survey_id, $question_id)
|
|
{
|
|
// table definitions
|
|
$table_survey_question = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY_QUESTION);
|
|
$table_survey_question_option = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY_QUESTION_OPTION);
|
|
|
|
// first we have to get the shared_question_id
|
|
$question_data = survey_manager::get_question($question_id);
|
|
|
|
// deleting the survey questions
|
|
$sql = "DELETE FROM $table_survey_question WHERE question_id='".Database::escape_string($question_data['shared_question_id'])."'";
|
|
$res = api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
// deleting the options of the question of the survey question
|
|
$sql = "DELETE FROM $table_survey_question_option WHERE question_id='".Database::escape_string($question_data['shared_question_id'])."'";
|
|
$res = api_sql_query($sql, __FILE__, __LINE__);
|
|
}
|
|
|
|
/******************************************************************************************************
|
|
SURVEY QUESTION OPTIONS FUNCTIONS
|
|
*****************************************************************************************************/
|
|
|
|
/**
|
|
* This function stores the options of the questions in the table
|
|
*
|
|
* @param array $form_content
|
|
* @return
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*
|
|
* @todo writing the update statement when editing a question
|
|
*/
|
|
function save_question_options($form_content, $survey_data)
|
|
{
|
|
// a percentage question type has options 1 -> 100
|
|
if ($form_content['type'] == 'percentage')
|
|
{
|
|
for($i=1;$i<101;$i++)
|
|
{
|
|
$form_content['answers'][] = $i;
|
|
}
|
|
}
|
|
|
|
if (is_numeric($survey_data['survey_share']) AND $survey_data['survey_share'] <> 0)
|
|
{
|
|
survey_manager::save_shared_question_options($form_content, $survey_data);
|
|
}
|
|
|
|
// table defintion
|
|
$table_survey_question_option = Database :: get_course_table(TABLE_SURVEY_QUESTION_OPTION);
|
|
|
|
// we are editing a question so we first have to remove all the existing options from the database
|
|
if (is_numeric($form_content['question_id']))
|
|
{
|
|
$sql = "DELETE FROM $table_survey_question_option WHERE question_id = '".Database::escape_string($form_content['question_id'])."'";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
}
|
|
|
|
$counter = 1;
|
|
if(is_array($form_content['answers'])){
|
|
foreach ($form_content['answers'] as $key=>$answer)
|
|
{
|
|
$sql = "INSERT INTO $table_survey_question_option (question_id, survey_id, option_text, sort) VALUES (
|
|
'".Database::escape_string($form_content['question_id'])."',
|
|
'".Database::escape_string($form_content['survey_id'])."',
|
|
'".Database::escape_string($answer)."',
|
|
'".Database::escape_string($counter)."')";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$counter++;
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* This function stores the options of the questions in the shared table
|
|
*
|
|
* @param array $form_content
|
|
* @return
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version February 2007
|
|
*
|
|
* @todo writing the update statement when editing a question
|
|
*/
|
|
function save_shared_question_options($form_content, $survey_data)
|
|
{
|
|
// table defintion
|
|
$table_survey_question_option = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY_QUESTION_OPTION);
|
|
|
|
// we are editing a question so we first have to remove all the existing options from the database
|
|
$sql = "DELETE FROM $table_survey_question_option WHERE question_id = '".Database::escape_string($form_content['shared_question_id'])."'";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
|
|
$counter = 1;
|
|
foreach ($form_content['answers'] as $key=>$answer)
|
|
{
|
|
$sql = "INSERT INTO $table_survey_question_option (question_id, survey_id, option_text, sort) VALUES (
|
|
'".Database::escape_string($form_content['shared_question_id'])."',
|
|
'".Database::escape_string($survey_data['is_shared'])."',
|
|
'".Database::escape_string($answer)."',
|
|
'".Database::escape_string($counter)."')";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$counter++;
|
|
}
|
|
}
|
|
|
|
/*
|
|
if (is_numeric($survey_data['survey_share']) AND $survey_data['survey_share'] <> 0)
|
|
{
|
|
$form_content = survey_manager::save_shared_question($form_content, $survey_data);
|
|
}
|
|
*/
|
|
|
|
|
|
/**
|
|
* This function deletes all the options of the questions of a given survey
|
|
* This function is normally only called when a survey is deleted
|
|
*
|
|
* @param $survey_id the id of the survey that has to be deleted
|
|
* @return true
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function delete_all_survey_questions_options($survey_id, $shared=false)
|
|
{
|
|
// table definitions
|
|
$table_survey_question_option = Database :: get_course_table(TABLE_SURVEY_QUESTION_OPTION);
|
|
if ($shared)
|
|
{
|
|
$table_survey_question = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY_QUESTION_OPTION);
|
|
}
|
|
|
|
// deleting the options of the survey questions
|
|
$sql = "DELETE from $table_survey_question_option WHERE survey_id='".Database::escape_string($survey_id)."'";
|
|
$res = api_sql_query($sql, __FILE__, __LINE__);
|
|
return true;
|
|
}
|
|
|
|
|
|
/**
|
|
* This function deletes the options of a given question
|
|
*
|
|
* @param unknown_type $survey_id
|
|
* @param unknown_type $question_id
|
|
* @param unknown_type $shared
|
|
* @return unknown
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version March 2007
|
|
*/
|
|
function delete_survey_question_option($survey_id, $question_id, $shared=false)
|
|
{
|
|
// table definitions
|
|
$table_survey_question_option = Database :: get_course_table(TABLE_SURVEY_QUESTION_OPTION);
|
|
if ($shared)
|
|
{
|
|
$table_survey_question = Database :: get_main_table(TABLE_MAIN_SHARED_SURVEY_QUESTION_OPTION);
|
|
}
|
|
|
|
// deleting the options of the survey questions
|
|
$sql = "DELETE from $table_survey_question_option WHERE survey_id='".Database::escape_string($survey_id)."' AND question_id='".Database::escape_string($question_id)."'";
|
|
$res = api_sql_query($sql, __FILE__, __LINE__);
|
|
return true;
|
|
}
|
|
|
|
|
|
|
|
/******************************************************************************************************
|
|
SURVEY ANSWERS FUNCTIONS
|
|
*****************************************************************************************************/
|
|
|
|
/**
|
|
* This function deletes all the answers anyone has given on this survey
|
|
* This function is normally only called when a survey is deleted
|
|
*
|
|
* @param $survey_id the id of the survey that has to be deleted
|
|
* @return true
|
|
*
|
|
* @todo write the function
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function delete_all_survey_answers($survey_id)
|
|
{
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* This function gets all the persons who have filled the survey
|
|
*
|
|
* @param integer $survey_id
|
|
* @return array
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version February 2007
|
|
*/
|
|
function get_people_who_filled_survey($survey_id, $all_user_info = false)
|
|
{
|
|
global $_course;
|
|
|
|
// Database table definition
|
|
$table_survey_answer = Database :: get_course_table(TABLE_SURVEY_ANSWER, $_course['db_name']);
|
|
$table_user = Database :: get_main_table('user');
|
|
|
|
// variable initialisation
|
|
$return = array();
|
|
|
|
// getting the survey information
|
|
$survey_data = survey_manager::get_survey($survey_id);
|
|
|
|
if ($all_user_info)
|
|
{
|
|
$sql = "SELECT DISTINCT answered_user.user as invited_user, user.firstname, user.lastname, user.user_id
|
|
FROM $table_survey_answer answered_user
|
|
LEFT JOIN $table_user as user
|
|
ON answered_user.user = user.user_id
|
|
WHERE survey_id= '".Database::escape_string($survey_data['survey_id'])."'";
|
|
}
|
|
else
|
|
{
|
|
$sql = "SELECT DISTINCT user FROM $table_survey_answer WHERE survey_id= '".Database::escape_string($survey_data['survey_id'])."'";
|
|
}
|
|
$res = api_sql_query($sql, __FILE__, __LINE__);
|
|
while ($row = Database::fetch_array($res,'ASSOC'))
|
|
{
|
|
if ($all_user_info)
|
|
{
|
|
$return[] = $row;
|
|
}
|
|
else
|
|
{
|
|
$return[] = $row['user'];
|
|
}
|
|
}
|
|
|
|
return $return;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class question
|
|
{
|
|
// the html code of the form
|
|
public $html;
|
|
|
|
/**
|
|
* This function does the generic part of any survey question: the question field
|
|
*
|
|
* @return unknown
|
|
*/
|
|
/**
|
|
* This function does the generic part of any survey question: the question field
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*
|
|
* @todo the form_text has to become a wysiwyg editor or adding a question_comment field
|
|
* @todo consider adding a question_comment form element
|
|
*/
|
|
function create_form($form_content)
|
|
{
|
|
global $fck_attribute;
|
|
$this->html = '<form id="question_form" name="question_form" method="post" action="'.api_get_self().'?action='.$_GET['action'].'&type='.$_GET['type'].'&survey_id='.$_GET['survey_id'].'&question_id='.$_GET['question_id'].'">';
|
|
$this->html .= ' <input type="hidden" name="survey_id" id="survey_id" value="'.$_GET['survey_id'].'"/>';
|
|
$this->html .= ' <input type="hidden" name="question_id" id="question_id" value="'.$_GET['question_id'].'"/>';
|
|
$this->html .= ' <input type="hidden" name="shared_question_id" id="shared_question_id" value="'.$form_content['shared_question_id'].'"/>';
|
|
$this->html .= ' <input type="hidden" name="type" id="type" value="'.$_GET['type'].'"/>';
|
|
$this->html .= '<table>';
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td colspan="3"><strong>'.get_lang('Question').'</strong></td>';
|
|
$this->html .= ' </tr>';
|
|
$this->html .= ' <tr>';
|
|
//$this->html .= ' <td><label for="question">'.get_lang('Question').'</label></td>';
|
|
$fck_attribute['Width'] = '100%';
|
|
$fck_attribute['Height'] = '100';
|
|
$fck_attribute['ToolbarSet'] = 'Survey';
|
|
//$this->html .= ' <td><input type="text" name="question" id="question" value="'.$form_content['question'].'"/></td>';
|
|
$this->html .= ' <td colspan="3" width="500">'.api_return_html_area('question', html_entity_decode(stripslashes($form_content['question']))).'</td>';
|
|
$this->html .= ' </tr>';
|
|
/*
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td><label for="question_comment">'.get_lang('QuestionComment').'</label></td>';
|
|
$this->html .= ' <td><input type="text" name="question_comment" id="question_comment" value="'.$form_content['question_comment'].'"/></td>';
|
|
$this->html .= ' <td> </td>';
|
|
$this->html .= ' </tr>';
|
|
*/
|
|
|
|
$this->html .=' <tr>
|
|
<td colspan=""> </td>
|
|
</tr>';
|
|
return $this->html;
|
|
}
|
|
|
|
/**
|
|
* This functions displays the form after the html variable has correctly been finished
|
|
* (adding a submit button, closing the table and closing the form)
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*
|
|
*/
|
|
function render_form()
|
|
{
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td> </td>';
|
|
$this->html .= ' <td> <input type="submit" name="save_question" value="'.get_lang('SaveQuestion').'" /></td>';
|
|
$this->html .= ' <td> </td>';
|
|
$this->html .= ' </tr>';
|
|
$this->html .= '</table>';
|
|
$this->html .= '</form>';
|
|
echo $this->html;
|
|
}
|
|
|
|
/**
|
|
* This function handles the actions on a question and its answers
|
|
*
|
|
* @todo consider using $form_content instead of $_POST
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function handle_action($form_content)
|
|
{
|
|
global $config;
|
|
|
|
// moving an answer up
|
|
if ($_POST['move_up'])
|
|
{
|
|
foreach ($_POST['move_up'] as $key=>$value)
|
|
{
|
|
$id1 = $key;
|
|
$content1 = $form_content['answers'][$id1];
|
|
$id2 = $key-1;
|
|
$content2 = $form_content['answers'][$id2];
|
|
$form_content['answers'][$id1] = $content2;
|
|
$form_content['answers'][$id2] = $content1;
|
|
}
|
|
}
|
|
|
|
// moving an answer down
|
|
if ($_POST['move_down'])
|
|
{
|
|
foreach ($_POST['move_down'] as $key=>$value)
|
|
{
|
|
$id1 = $key;
|
|
$content1 = $form_content['answers'][$id1];
|
|
$id2 = $key+1;
|
|
$content2 = $form_content['answers'][$id2];
|
|
$form_content['answers'][$id1] = $content2;
|
|
$form_content['answers'][$id2] = $content1;
|
|
}
|
|
}
|
|
|
|
// adding an answer
|
|
if ($_POST['add_answer'])
|
|
{
|
|
$form_content['answers'][]='';
|
|
}
|
|
|
|
// removing an answer
|
|
if ($_POST['remove_answer'])
|
|
{
|
|
$max_answer = count($form_content['answers']);
|
|
unset($form_content['answers'][$max_answer-1]);
|
|
}
|
|
|
|
// saving a question
|
|
if ($_POST['save_question'])
|
|
{
|
|
$message = survey_manager::save_question($form_content);
|
|
if ($config['survey']['debug'])
|
|
{
|
|
Display :: display_header();
|
|
Display :: display_confirmation_message($message.'<br />'.get_lang('ReturnTo').' <a href="survey.php?survey_id='.$_GET['survey_id'].'">'.get_lang('Survey').'</a>', false);
|
|
}
|
|
else
|
|
{
|
|
header('location:survey.php?survey_id='.$_GET['survey_id'].'&message='.$message);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* This solution is a little bit strange but I could not find a different solution.
|
|
*/
|
|
if ($_POST['delete_answer'])
|
|
{
|
|
foreach ($_POST['delete_answer'] as $key=>$value)
|
|
{
|
|
unset($form_content['answers'][$key]);
|
|
$deleted = $key;
|
|
}
|
|
foreach ($form_content['answers'] as $key=>$value)
|
|
{
|
|
if ($key>$deleted)
|
|
{
|
|
$form_content['answers'][$key-1] = $form_content['answers'][$key];
|
|
unset($form_content['answers'][$key]);
|
|
}
|
|
}
|
|
}
|
|
return $form_content;
|
|
}
|
|
|
|
/**
|
|
* This functions adds two buttons. One to add an option, one to remove an option
|
|
*
|
|
* @param unknown_type $form_content
|
|
* @return html code
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function add_remove_buttons($form_content)
|
|
{
|
|
if (count($form_content['answers'])<=2)
|
|
{
|
|
$remove_answer_attribute = 'disabled="disabled"';
|
|
}
|
|
|
|
$return .= ' <tr>';
|
|
$return .= ' <td align="right"> </td>';
|
|
$return .= ' <td colspan="2">';
|
|
$return .= ' <input type="submit" name="remove_answer" value="'.get_lang('RemoveAnswer').'" '.$remove_answer_attribute.' />';
|
|
$return .= ' <input type="submit" name="add_answer" value="'.get_lang('AddAnswer').'" />';
|
|
$return .= ' </td>';
|
|
$return .= ' </tr>';
|
|
return $return;
|
|
}
|
|
|
|
|
|
/**
|
|
* render the question. In this case this starts with the form tag
|
|
*
|
|
* @param unknown_type $form_content
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function render_question($form_content)
|
|
{
|
|
$this->html = '<form id="question" name="question" method="post" action="'.api_get_self().'?survey_id='.$_GET['survey_id'].'">';
|
|
echo $this->html;
|
|
}
|
|
}
|
|
|
|
class yesno extends question
|
|
{
|
|
/**
|
|
* This function creates the form elements for the yesno questions
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function create_form($form_content)
|
|
{
|
|
$this->html = parent::create_form($form_content);
|
|
// Horizontal or vertical
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td colspan="2"><strong>'.get_lang('DisplayAnswersHorVert').'</strong></td>';
|
|
$this->html .= ' </tr>';
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td align="right" valign="top"> </td>';
|
|
$this->html .= ' <td>';
|
|
$this->html .= ' <input name="horizontalvertical" type="radio" value="horizontal" ';
|
|
if ($form_content['horizontalvertical'] == 'horizontal')
|
|
{
|
|
$this->html .= 'checked="checked"';
|
|
}
|
|
$this->html .= '/>'.get_lang('Horizontal').'</label><br />';
|
|
$this->html .= ' <input name="horizontalvertical" type="radio" value="vertical" ';
|
|
if ($form_content['horizontalvertical'] == 'vertical')
|
|
{
|
|
$this->html .= 'checked="checked"';
|
|
}
|
|
$this->html .= ' />'.get_lang('Vertical').'</label>';
|
|
$this->html .= ' </td>';
|
|
$this->html .= ' <td> </td>';
|
|
$this->html .= ' </tr>';
|
|
$this->html .=' <tr>
|
|
<td colspan=""> </td>
|
|
</tr>';
|
|
|
|
// The options
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td colspan="3"><strong>'.get_lang('AnswerOptions').'</strong></td>';
|
|
$this->html .= ' </tr>';
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td align="right"><label for="answers[0]">1</label></td>';
|
|
//$this->html .= ' <td><input type="text" name="answers[0]" id="answers[0]" value="'.$form_content['answers'][0].'" /></td>';
|
|
$this->html .= ' <td>'.api_return_html_area('answers[0]', stripslashes($form_content['answers'][0])).'</td>';
|
|
$this->html .= ' <td><input type="image" src="../img/down.gif" value="move_down[0]" name="move_down[0]"/></td>';
|
|
$this->html .= ' </tr>';
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td align="right"><label for="answers[1]">2</label></td>';
|
|
//$this->html .= ' <td><input type="text" name="answers[1]" id="answers[1]" value="'.$form_content['answers'][1].'" /></td>';
|
|
$this->html .= ' <td>'.api_return_html_area('answers[1]', stripslashes($form_content['answers'][1])).'</td>';
|
|
$this->html .= ' <td><input type="image" src="../img/up.gif" value="move_up[1]" name="move_up[1]" /></td>';
|
|
$this->html .= ' </tr>';
|
|
}
|
|
|
|
/**
|
|
* Render the yes not question type
|
|
*
|
|
* @param unknown_type $form_content
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function render_question($form_content, $answers=array())
|
|
{
|
|
foreach ($form_content['options'] as $key=>$value)
|
|
{
|
|
$this->html .= '<label><input name="question'.$form_content['question_id'].'" type="radio" value="'.$key.'"';
|
|
if (in_array($key,$answers))
|
|
{
|
|
$this->html .= 'checked="checked"';
|
|
}
|
|
$this->html .= '/>'.$value.'</label>';
|
|
if ($form_content['display'] == 'vertical')
|
|
{
|
|
$this->html .= '<br />';
|
|
}
|
|
}
|
|
echo '<div class="survey_question_wrapper">';
|
|
echo '<div class="survey_question">'.$form_content['survey_question'].'</div>';
|
|
echo '<div class="survey_question_options">';
|
|
echo $this->html;
|
|
echo '</div>';
|
|
echo '</div>';
|
|
}
|
|
|
|
}
|
|
|
|
class multiplechoice extends question
|
|
{
|
|
/**
|
|
* This function creates the form elements for the multiple choice questions
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function create_form($form_content)
|
|
{
|
|
$this->html = parent::create_form($form_content);
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td colspan="2"><strong>'.get_lang('DisplayAnswersHorVert').'</strong></td>';
|
|
$this->html .= ' </tr>';
|
|
// Horizontal or vertical
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td align="right" valign="top"> </td>';
|
|
$this->html .= ' <td>';
|
|
$this->html .= ' <input name="horizontalvertical" type="radio" value="horizontal" ';
|
|
if ($form_content['horizontalvertical'] == 'horizontal')
|
|
{
|
|
$this->html .= 'checked="checked"';
|
|
}
|
|
$this->html .= '/>'.get_lang('Horizontal').'</label><br />';
|
|
$this->html .= ' <input name="horizontalvertical" type="radio" value="vertical" ';
|
|
if ($form_content['horizontalvertical'] == 'vertical')
|
|
{
|
|
$this->html .= 'checked="checked"';
|
|
}
|
|
$this->html .= ' />'.get_lang('Vertical').'</label>'; $this->html .= ' </td>';
|
|
$this->html .= ' <td> </td>';
|
|
$this->html .= ' </tr>';
|
|
$this->html .=' <tr>
|
|
<td colspan=""> </td>
|
|
</tr>';
|
|
|
|
// The Options
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td colspan="3"><strong>'.get_lang('AnswerOptions').'</strong></td>';
|
|
$this->html .= ' </tr>';
|
|
$total_number_of_answers = count($form_content['answers']);
|
|
foreach ($form_content['answers'] as $key=>$value)
|
|
{
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td align="right"><label for="answers['.$key.']">'.($key+1).'</label></td>';
|
|
//$this->html .= ' <td><input type="text" name="answers['.$key.']" id="answers['.$key.']" value="'.$form_content['answers'][$key].'" /></td>';
|
|
$this->html .= ' <td width="500">'.api_return_html_area('answers['.$key.']', html_entity_decode(stripslashes($form_content['answers'][$key]))).'</td>';
|
|
$this->html .= ' <td>';
|
|
if ($key<$total_number_of_answers-1)
|
|
{
|
|
$this->html .= ' <input type="image" src="../img/down.gif" value="move_down['.$key.']" name="move_down['.$key.']"/>';
|
|
}
|
|
else
|
|
{
|
|
$this->html .= ' <img src="../img/spacer.gif" alt="'.get_lang('Empty').'" title="'.get_lang('Empty').'" />';
|
|
}
|
|
if ($key>0)
|
|
{
|
|
$this->html .= ' <input type="image" src="../img/up.gif" value="move_up['.$key.']" name="move_up['.$key.']"/>';
|
|
}
|
|
else
|
|
{
|
|
$this->html .= ' <img src="../img/spacer.gif" alt="'.get_lang('Empty').'" title="'.get_lang('Empty').'" />';
|
|
}
|
|
if ($total_number_of_answers> 2)
|
|
{
|
|
$this->html .= ' <input type="image" src="../img/delete.gif" value="delete_answer['.$key.']" name="delete_answer['.$key.']"/>';
|
|
}
|
|
$this->html .= ' </td>';
|
|
$this->html .= ' </tr>';
|
|
}
|
|
// The buttons for adding or removing
|
|
$this->html .= parent :: add_remove_buttons($form_content);
|
|
}
|
|
|
|
/**
|
|
* render the multiple choice question type
|
|
*
|
|
* @param unknown_type $form_content
|
|
*
|
|
* @todo it would make more sense to consider yesno as a special case of multiplechoice and not the other way around
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function render_question($form_content, $answers=array())
|
|
{
|
|
$question = new yesno();
|
|
$question->render_question($form_content, $answers);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
class multipleresponse extends question
|
|
{
|
|
/**
|
|
* This function creates the form elements for the multiple response questions
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function create_form($form_content)
|
|
{
|
|
$this->html = parent::create_form($form_content);
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td colspan="2"><strong>'.get_lang('DisplayAnswersHorVert').'</strong></td>';
|
|
$this->html .= ' </tr>';
|
|
// Horizontal or vertical
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td align="right" valign="top"> </td>';
|
|
$this->html .= ' <td>';
|
|
$this->html .= ' <input name="horizontalvertical" type="radio" value="horizontal" ';
|
|
if ($form_content['horizontalvertical'] == 'horizontal')
|
|
{
|
|
$this->html .= 'checked="checked"';
|
|
}
|
|
$this->html .= '/>'.get_lang('Horizontal').'</label><br />';
|
|
$this->html .= ' <input name="horizontalvertical" type="radio" value="vertical" ';
|
|
if ($form_content['horizontalvertical'] == 'vertical')
|
|
{
|
|
$this->html .= 'checked="checked"';
|
|
}
|
|
$this->html .= ' />'.get_lang('Vertical').'</label>'; $this->html .= ' </td>';
|
|
$this->html .= ' <td> </td>';
|
|
$this->html .= ' </tr>';
|
|
$this->html .=' <tr>
|
|
<td colspan=""> </td>
|
|
</tr>';
|
|
|
|
|
|
// The options
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td colspan="3"><strong>'.get_lang('AnswerOptions').'</strong></td>';
|
|
$this->html .= ' </tr>';
|
|
$total_number_of_answers = count($form_content['answers']);
|
|
foreach ($form_content['answers'] as $key=>$value)
|
|
{
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td align="right"><label for="answers['.$key.']">'.($key+1).'</label></td>';
|
|
//$this->html .= ' <td><input type="text" name="answers['.$key.']" id="answers['.$key.']" value="'.$form_content['answers'][$key].'" /></td>';
|
|
$this->html .= ' <td width="500">'.api_return_html_area('answers['.$key.']', html_entity_decode(stripslashes($form_content['answers'][$key]))).'</td>';
|
|
$this->html .= ' <td>';
|
|
if ($key<$total_number_of_answers-1)
|
|
{
|
|
$this->html .= ' <input type="image" src="../img/down.gif" value="move_down['.$key.']" name="move_down['.$key.']"/>';
|
|
}
|
|
else
|
|
{
|
|
$this->html .= ' <img src="../img/spacer.gif" alt="'.get_lang('Empty').'" title="'.get_lang('Empty').'" />';
|
|
}
|
|
if ($key>0)
|
|
{
|
|
$this->html .= ' <input type="image" src="../img/up.gif" value="move_up['.$key.']" name="move_up['.$key.']"/>';
|
|
}
|
|
else
|
|
{
|
|
$this->html .= ' <img src="../img/spacer.gif" alt="'.get_lang('Empty').'" title="'.get_lang('Empty').'" />';
|
|
}
|
|
if ($total_number_of_answers> 2)
|
|
{
|
|
$this->html .= ' <input type="image" src="../img/delete.gif" value="delete_answer['.$key.']" name="delete_answer['.$key.']"/>';
|
|
}
|
|
$this->html .= ' </td>';
|
|
$this->html .= ' </tr>';
|
|
}
|
|
// The buttons for adding or removing
|
|
$this->html .= parent :: add_remove_buttons($form_content);
|
|
}
|
|
|
|
/**
|
|
* Render the multiple response question type
|
|
*
|
|
* @param unknown_type $form_content
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function render_question($form_content, $answers=array())
|
|
{
|
|
foreach ($form_content['options'] as $key=>$value)
|
|
{
|
|
$this->html .= '<label><input name="question'.$form_content['question_id'].'[]" type="checkbox" value="'.$key.'"';
|
|
if (in_array($key,$answers))
|
|
{
|
|
$this->html .= 'checked="checked"';
|
|
}
|
|
$this->html .= ' />'.$value.'</label>';
|
|
if ($form_content['display'] == 'vertical')
|
|
{
|
|
$this->html .= '<br />';
|
|
}
|
|
}
|
|
echo '<div class="survey_question_wrapper">';
|
|
echo '<div class="survey_question">'.$form_content['survey_question'].'</div>';
|
|
echo '<div class="survey_question_options">';
|
|
echo $this->html;
|
|
echo '</div>';
|
|
}
|
|
}
|
|
|
|
class dropdown extends question
|
|
{
|
|
/**
|
|
* This function creates the form elements for the dropdown questions
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function create_form($form_content)
|
|
{
|
|
$this->html = parent::create_form($form_content);
|
|
// The answers
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td colspan="3"><strong>'.get_lang('AnswerOptions').'</strong></td>';
|
|
$this->html .= ' </tr>';
|
|
$total_number_of_answers = count($form_content['answers']);
|
|
foreach ($form_content['answers'] as $key=>$value)
|
|
{
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td align="right"><label for="answers['.$key.']">'.($key+1).'</label></td>';
|
|
$this->html .= ' <td><input type="text" name="answers['.$key.']" id="answers['.$key.']" value="'.stripslashes(htmlentities($form_content['answers'][$key])).'" /></td>';
|
|
$this->html .= ' <td>';
|
|
if ($key<$total_number_of_answers-1)
|
|
{
|
|
$this->html .= ' <input type="image" src="../img/down.gif" value="move_down['.$key.']" name="move_down['.$key.']"/>';
|
|
}
|
|
if ($key>0)
|
|
{
|
|
$this->html .= ' <input type="image" src="../img/up.gif" value="move_up['.$key.']" name="move_up['.$key.']"/>';
|
|
}
|
|
if ($total_number_of_answers> 2)
|
|
{
|
|
$this->html .= ' <input type="image" src="../img/delete.gif" value="delete_answer['.$key.']" name="delete_answer['.$key.']"/>';
|
|
}
|
|
$this->html .= ' </td>';
|
|
$this->html .= ' </tr>';
|
|
}
|
|
// The buttons for adding or removing
|
|
$this->html .= parent :: add_remove_buttons($form_content);
|
|
}
|
|
|
|
/**
|
|
* Render the dropdown question type
|
|
*
|
|
* @param unknown_type $form_content
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function render_question($form_content, $answers=array())
|
|
{
|
|
|
|
foreach ($form_content['options'] as $key=>$value)
|
|
{
|
|
$this->html .= '<option value="'.$key.'" ';
|
|
if (in_array($key,$answers))
|
|
{
|
|
$this->html .= 'selected="selected"';
|
|
}
|
|
$this->html .= '>'.$value.'</option>';
|
|
}
|
|
echo '<div class="survey_question_wrapper">';
|
|
echo '<div class="survey_question">'.$form_content['survey_question'].'</div>';
|
|
echo '<div class="survey_question_options">';
|
|
echo '<select name="question'.$form_content['question_id'].'" id="select">';
|
|
echo $this->html;
|
|
echo '</select>';
|
|
echo '</div>';
|
|
/*
|
|
|
|
|
|
<option value="test">test</option>
|
|
|
|
*/
|
|
}
|
|
}
|
|
|
|
|
|
class open extends question
|
|
{
|
|
/**
|
|
* This function creates the form elements for the open questions
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*
|
|
* @todo add a limit for the number of characters that can be type
|
|
* @todo add a checkbox weither the answer is a textarea or a wysiwyg editor
|
|
*/
|
|
function create_form($form_content)
|
|
{
|
|
$this->html = parent::create_form($form_content);
|
|
}
|
|
|
|
/**
|
|
* render the open question type
|
|
*
|
|
* @param unknown_type $form_content
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function render_question($form_content, $answers=array())
|
|
{
|
|
echo '<div class="survey_question_wrapper">';
|
|
echo '<div class="survey_question">'.$form_content['survey_question'].'</div>';
|
|
echo '<div class="survey_question_options">';
|
|
if (is_array($answers))
|
|
{
|
|
$content = implode('',$answers);
|
|
}
|
|
else
|
|
{
|
|
$content = $answers;
|
|
}
|
|
echo '<label for="question'.$form_content['question_id'].'"></label><textarea name="question'.$form_content['question_id'].'" id="textarea" style="width: 400px; height: 130px;">'.$content.'</textarea>';
|
|
echo '</div>';
|
|
}
|
|
}
|
|
|
|
class comment extends question
|
|
{
|
|
/**
|
|
* This function creates the form elements for a comment.
|
|
* A comment is nothing more than a block of text that the user can read
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*
|
|
* @param array $form_content
|
|
*/
|
|
function create_form($form_content)
|
|
{
|
|
$this->html = parent::create_form($form_content);
|
|
}
|
|
|
|
|
|
/**
|
|
* Render the comment "question" type
|
|
*
|
|
* @param unknown_type $form_content
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*/
|
|
function render_question($form_content)
|
|
{
|
|
echo '<div class="survey_question_wrapper">';
|
|
echo '<div class="survey_question">'.$form_content['survey_question'].'</div>';
|
|
echo '</div>';
|
|
echo "\n";
|
|
}
|
|
}
|
|
|
|
class pagebreak extends question
|
|
{
|
|
/**
|
|
* This function creates the form elements for a comment.
|
|
* A comment is nothing more than a block of text that the user can read
|
|
*
|
|
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
|
|
* @version January 2007
|
|
*
|
|
* @param array $form_content
|
|
*/
|
|
function create_form($form_content)
|
|
{
|
|
$this->html = parent::create_form($form_content);
|
|
}
|
|
}
|
|
|
|
class percentage extends question
|
|
{
|
|
function create_form($form_content)
|
|
{
|
|
$this->html = parent::create_form($form_content);
|
|
}
|
|
|
|
function render_question($form_content, $answers=array())
|
|
{
|
|
$this->html .= '<option value="--">--</option>';
|
|
foreach ($form_content['options'] as $key=>$value)
|
|
{
|
|
$this->html .= '<option value="'.$key.'" ';
|
|
if (in_array($key,$answers))
|
|
{
|
|
$this->html .= 'selected="selected"';
|
|
}
|
|
$this->html .= '>'.$value.'</option>';
|
|
}
|
|
echo '<div class="survey_question_wrapper">';
|
|
echo '<div class="survey_question">'.$form_content['survey_question'].'</div>';
|
|
echo '<div class="survey_question_options">';
|
|
echo '<select name="question'.$form_content['question_id'].'" id="select">';
|
|
echo $this->html;
|
|
echo '</select>';
|
|
echo '</div>';
|
|
}
|
|
}
|
|
|
|
|
|
class score extends question
|
|
{
|
|
function create_form($form_content)
|
|
{
|
|
$this->html = parent::create_form($form_content);
|
|
// the maximum score that can be given
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td colspan="3"><strong>'.get_lang('MaximumScore').'</strong></td>';
|
|
$this->html .= ' </tr>';
|
|
$this->html .= ' <tr>
|
|
<td colspan="3"><input type="text" name="maximum_score" value="'.$form_content['maximum_score'].'"></td>
|
|
</tr>';
|
|
// The answers
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td colspan="3"><strong>'.get_lang('AnswerOptions').'</strong></td>';
|
|
$this->html .= ' </tr>';
|
|
$total_number_of_answers = count($form_content['answers']);
|
|
foreach ($form_content['answers'] as $key=>$value)
|
|
{
|
|
$this->html .= ' <tr>';
|
|
$this->html .= ' <td align="right"><label for="answers['.$key.']">'.($key+1).'</label></td>';
|
|
//$this->html .= ' <td><input type="text" name="answers['.$key.']" id="answers['.$key.']" value="'.$form_content['answers'][$key].'" /></td>';
|
|
$this->html .= ' <td width="500">'.api_return_html_area('answers['.$key.']', stripslashes($form_content['answers'][$key])).'</td>';
|
|
$this->html .= ' <td>';
|
|
if ($key<$total_number_of_answers-1)
|
|
{
|
|
$this->html .= ' <input type="image" src="../img/down.gif" value="move_down['.$key.']" name="move_down['.$key.']"/>';
|
|
}
|
|
if ($key>0)
|
|
{
|
|
$this->html .= ' <input type="image" src="../img/up.gif" value="move_up['.$key.']" name="move_up['.$key.']"/>';
|
|
}
|
|
if ($total_number_of_answers> 2)
|
|
{
|
|
$this->html .= ' <input type="image" src="../img/delete.gif" value="delete_answer['.$key.']" name="delete_answer['.$key.']"/>';
|
|
}
|
|
$this->html .= ' </td>';
|
|
$this->html .= ' </tr>';
|
|
}
|
|
// The buttons for adding or removing
|
|
$this->html .= parent :: add_remove_buttons($form_content);
|
|
}
|
|
|
|
function render_question($form_content, $answers=array())
|
|
{
|
|
/*
|
|
echo '<div style="border: 1px solid red;">';
|
|
echo '<pre>';
|
|
print_r($answers);
|
|
echo '</pre></div>';
|
|
*/
|
|
$this->html = '<table>';
|
|
foreach ($form_content['options'] as $key=>$value)
|
|
{
|
|
$this->html .= '<tr>
|
|
<td>'.$value.'</td>';
|
|
$this->html .= ' <td>';
|
|
$this->html .= '<select name="question'.$form_content['question_id'].'['.$key.']">';
|
|
$this->html .= '<option value="--">--</option>';
|
|
for($i=1; $i<=$form_content['maximum_score']; $i++)
|
|
{
|
|
$this->html .= '<option value="'.$i.'"';
|
|
if ($answers[$key] == $i)
|
|
{
|
|
$this->html .= 'selected="selected" ';
|
|
}
|
|
$this->html .= '>'.$i.'</option>';
|
|
}
|
|
$this->html .= '</select>';
|
|
$this->html .= ' </td>';
|
|
$this->html .= '</tr>';
|
|
}
|
|
$this->html .= '</table>';
|
|
echo '<div class="survey_question_wrapper">';
|
|
echo '<div class="survey_question">'.$form_content['survey_question'].'</div>';
|
|
echo '<div class="survey_question_options">';
|
|
//echo '<select name="question'.$form_content['question_id'].'" id="select">';
|
|
echo $this->html;
|
|
//echo '</select>';
|
|
echo '</div>';
|
|
}
|
|
}
|
|
|
|
function db_escape_string($value)
|
|
{
|
|
|
|
}
|
|
|
|
function check_first_last_question($survey_id, $continue=true)
|
|
{
|
|
// table definitions
|
|
$tbl_survey_question = Database :: get_course_table(TABLE_SURVEY_QUESTION);
|
|
$table_survey_question_option = Database :: get_course_table(TABLE_SURVEY_QUESTION_OPTION);
|
|
|
|
// getting the information of the question
|
|
$sql = "SELECT * FROM $tbl_survey_question WHERE survey_id='".Database::escape_string($survey_id)."' ORDER BY sort ASC";
|
|
$result = api_sql_query($sql, __FILE__, __LINE__);
|
|
$total = Database::num_rows($result);
|
|
$counter=1;
|
|
$error = false;
|
|
while ($row = Database::fetch_array($result,'ASSOC'))
|
|
{
|
|
if ($counter == 1 AND $row['type'] == 'pagebreak')
|
|
{
|
|
Display::display_error_message(get_lang('PagebreakNotFirst'), false);
|
|
$error = true;
|
|
}
|
|
if ($counter == $total AND $row['type'] == 'pagebreak')
|
|
{
|
|
Display::display_error_message(get_lang('PagebreakNotLast'), false);
|
|
$error = true;
|
|
}
|
|
$counter++;
|
|
}
|
|
|
|
if (!$continue AND $error)
|
|
{
|
|
Display::display_footer();
|
|
exit;
|
|
}
|
|
}
|
|
?>
|