, Ghent University: cleanup, refactoring and rewriting large parts of the code * @version $Id: survey.php 14639 2008-03-18 05:31:08Z yannoo $ * * @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'); require_once (api_get_path(LIBRARY_PATH)."/course.lib.php"); /** @todo this has to be moved to a more appropriate place (after the display_header of the code)*/ if (!api_is_allowed_to_edit()) { Display :: display_header(get_lang('Survey')); Display :: display_error_message(get_lang('NotAllowed'), false); Display :: display_footer(); exit; } // 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); $user_info = Database :: get_main_table(TABLE_MAIN_SURVEY_REMINDER); // breadcrumbs $interbreadcrumb[] = array ("url" => "survey_list.php", "name" => get_lang('SurveyList')); // getting the survey information $survey_data = survey_manager::get_survey($_GET['survey_id']); $tool_name = substr(strip_tags($survey_data['title']), 0, 40); if (strlen(strip_tags($survey_data['title'])) > 40) { $tool_name .= '...'; } // Displaying the header Display::display_header($tool_name); // Action handling if (isset($_GET['action'])) { if (($_GET['action'] == 'moveup' OR $_GET['action'] == 'movedown') AND isset($_GET['question_id'])) { survey_manager::move_survey_question($_GET['action'], $_GET['question_id'], $_GET['survey_id']); Display::display_confirmation_message('SurveyQuestionMoved', false); } if ($_GET['action'] == 'delete' AND is_numeric($_GET['question_id'])) { survey_manager::delete_survey_question($_GET['survey_id'], $_GET['question_id'], $survey_data['is_shared']); } } if (isset($_GET['message'])) { // we have created the survey or updated the survey if (in_array($_GET['message'], array('SurveyUpdatedSuccesfully','SurveyCreatedSuccesfully'))) { Display::display_confirmation_message(get_lang($_GET['message']).'
'.get_lang('YouCanNowAddQuestionToYourSurvey'), false); } // we have added a question if (in_array($_GET['message'], array('QuestionAdded','QuestionUpdated'))) { Display::display_confirmation_message(get_lang($_GET['message']), false); } } // We exit here is the first or last question is a pagebreak (which causes errors) SurveyUtil::check_first_last_question($_GET['survey_id']); // Action links $survey_actions = get_lang('Survey').': '; $survey_actions .= ''.Display::return_icon('edit.gif', get_lang('Edit')).''; $survey_actions .= ''.Display::return_icon('delete.gif', get_lang('Delete')).''; //$survey_actions .= ''.Display::return_icon('copy.gif', get_lang('Copy')).''; $survey_actions .= ''.Display::return_icon('preview.gif', get_lang('Preview')).''; $survey_actions .= ''.Display::return_icon('survey_publish.gif', get_lang('Publish')).''; $survey_actions .= ''.Display::return_icon('statistics.gif', get_lang('Reporting')).''; echo '
'.$survey_actions.'
'; echo '
'; echo '

'.get_lang('YesNo').'
'; echo '

'.get_lang('MultipleChoice').'
'; echo '

'.get_lang('MultipleResponse').'
'; echo '

'.get_lang('Open').'
'; echo '

'.get_lang('Dropdown').'
'; echo '

'.get_lang('Percentage').'
'; echo '

'.get_lang('Score').'
'; echo '

'.get_lang('Comment').'
'; echo '

'.get_lang('Pagebreak').'
'; echo '
'; echo '
'; // Displaying the table header with all the questions echo ''; echo ' '; echo ' '; echo ' '; echo ' '; echo ' '; echo ' '; echo ' '; // Displaying the table contents with all the questions $question_counter = 1; $sql = "SELECT survey_question.*, count(survey_question_option.question_option_id) as number_of_options 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($_GET['survey_id'])."' GROUP BY survey_question.question_id ORDER BY survey_question.sort ASC"; $result = api_sql_query($sql, __FILE__, __LINE__); $question_counter_max = mysql_num_rows($result); while ($row = mysql_fetch_assoc($result)) { echo ''; echo ' '; echo ' '; echo ' '; echo ' '; echo ' '; $question_counter++; } echo '
'.get_lang('QuestionNumber').''.get_lang('Title').''.get_lang('Type').''.get_lang('NumberOfOptions').''.get_lang('Modify').'
'.$question_counter.''; if (strlen($row['survey_question']) > 100) { echo substr(strip_tags($row['survey_question']),0, 100).' ... '; } else { echo $row['survey_question']; } echo ''.get_lang(ucfirst($row['type'])).''.$row['number_of_options'].''; echo ' '.Display::return_icon('edit.gif', get_lang('Edit')).''; echo ' '.Display::return_icon('delete.gif', get_lang('Delete')).''; if ($question_counter > 1) { echo ' '.Display::return_icon('up.gif', get_lang('MoveUp')).''; } if ($question_counter < $question_counter_max) { echo ' '.Display::return_icon('down.gif', get_lang('MoveDown')).''; } echo '
'; // Footer Display :: display_footer(); ?>