survey_invitation.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. <?php
  2. /* For licensing terms, see /license.txt */
  3. /**
  4. * @package chamilo.survey
  5. * @author Patrick Cool <patrick.cool@UGent.be>, Ghent University: cleanup, refactoring and rewriting large parts of the code
  6. * @version $Id: survey_invite.php 10680 2007-01-11 21:26:23Z pcool $
  7. *
  8. * @todo the answered column
  9. */
  10. // Language file that needs to be included
  11. $language_file = 'survey';
  12. // Including the global initialization file
  13. require '../inc/global.inc.php';
  14. // Including additional libraries
  15. require_once 'survey.lib.php';
  16. /** @todo this has to be moved to a more appropriate place (after the display_header of the code) */
  17. if (!api_is_allowed_to_edit(false, true)) {
  18. Display :: display_header(get_lang('ToolSurvey'));
  19. Display :: display_error_message(get_lang('NotAllowed'), false);
  20. Display :: display_footer();
  21. exit;
  22. }
  23. // Database table definitions
  24. $table_survey = Database :: get_course_table(TABLE_SURVEY);
  25. $table_survey_question = Database :: get_course_table(TABLE_SURVEY_QUESTION);
  26. $table_survey_question_option = Database :: get_course_table(TABLE_SURVEY_QUESTION_OPTION);
  27. $table_course = Database :: get_main_table(TABLE_MAIN_COURSE);
  28. $table_user = Database :: get_main_table(TABLE_MAIN_USER);
  29. $table_survey_invitation = Database :: get_course_table(TABLE_SURVEY_INVITATION);
  30. $tool_name = get_lang('SurveyInvitations');
  31. // Getting the survey information
  32. // We exit here if ther is no valid $_GET parameter
  33. if (!isset($_GET['survey_id']) OR !is_numeric($_GET['survey_id'])) {
  34. Display :: display_header($tool_name);
  35. Display :: display_error_message(get_lang('InvallidSurvey'), false);
  36. Display :: display_footer();
  37. exit;
  38. }
  39. $survey_id = Security::remove_XSS($_GET['survey_id']);
  40. $survey_data = survey_manager::get_survey($survey_id);
  41. if (empty($survey_data)) {
  42. Display :: display_header($tool_name);
  43. Display :: display_error_message(get_lang('InvallidSurvey'), false);
  44. Display :: display_footer();
  45. exit;
  46. }
  47. $urlname = strip_tags(api_substr(api_html_entity_decode($survey_data['title'], ENT_QUOTES), 0, 40));
  48. if (api_strlen(strip_tags($survey_data['title'])) > 40) {
  49. $urlname .= '...';
  50. }
  51. // Breadcrumbs
  52. $interbreadcrumb[] = array('url' => 'survey_list.php', 'name' => get_lang('SurveyList'));
  53. $interbreadcrumb[] = array('url' => 'survey.php?survey_id='.$survey_id, 'name' => $urlname);
  54. // Displaying the header
  55. Display::display_header($tool_name);
  56. // Checking the parameters
  57. if (!is_numeric($survey_id)) {
  58. Display::display_error_message(get_lang('Error'), false);
  59. Display::display_footer();
  60. exit;
  61. }
  62. // Getting all the people who have filled this survey
  63. $answered_data = survey_manager::get_people_who_filled_survey($survey_id);
  64. if ($survey_data['anonymous'] == 1) {
  65. Display::display_normal_message(get_lang('AnonymousSurveyCannotKnowWhoAnswered').' '.count($answered_data).' '.get_lang('PeopleAnswered'));
  66. $answered_data = array();
  67. }
  68. if (!isset($_GET['view']) OR $_GET['view'] == 'invited') {
  69. echo get_lang('ViewInvited').' | ';
  70. } else {
  71. echo ' <a href="'.api_get_self().'?survey_id='.$survey_id.'&amp;view=invited">'.get_lang('ViewInvited').'</a> |';
  72. }
  73. if ($_GET['view'] == 'answered') {
  74. echo get_lang('ViewAnswered').' | ';
  75. } else {
  76. echo ' <a href="'.api_get_self().'?survey_id='.$survey_id.'&amp;view=answered">'.get_lang('ViewAnswered').'</a> |';
  77. }
  78. if ($_GET['view'] == 'unanswered') {
  79. echo get_lang('ViewUnanswered');
  80. } else {
  81. echo ' <a href="'.api_get_self().'?survey_id='.$survey_id.'&amp;view=unanswered">'.get_lang('ViewUnanswered').'</a>';
  82. }
  83. // Table header
  84. echo '<table class="data_table">';
  85. echo ' <tr>';
  86. echo ' <th>'.get_lang('User').'</th>';
  87. echo ' <th>'.get_lang('InvitationDate').'</th>';
  88. echo ' <th>'.get_lang('Answered').'</th>';
  89. echo ' </tr>';
  90. $course_id = api_get_course_int_id();
  91. $sql = "SELECT survey_invitation.*, user.firstname, user.lastname, user.email
  92. FROM $table_survey_invitation survey_invitation
  93. LEFT JOIN $table_user user ON (survey_invitation.user = user.user_id AND survey_invitation.c_id = $course_id)
  94. WHERE survey_invitation.survey_code = '".Database::escape_string($survey_data['code'])."' AND group_id = 0 ";
  95. $res = Database::query($sql);
  96. while ($row = Database::fetch_assoc($res)) {
  97. if (!$_GET['view'] || $_GET['view'] == 'invited' || ($_GET['view'] == 'answered' && in_array($row['user'], $answered_data)) || ($_GET['view'] == 'unanswered' && !in_array($row['user'], $answered_data))) {
  98. echo '<tr>';
  99. if (is_numeric($row['user'])) {
  100. echo ' <td><a href="../user/userInfo.php?editMainUserInfo='.$row['user'].'">'.api_get_person_name($row['firstname'], $row['lastname']).'</a></td>';
  101. } else {
  102. echo ' <td>'.$row['user'].'</td>';
  103. }
  104. echo ' <td>'.$row['invitation_date'].'</td>';
  105. echo ' <td>';
  106. if (in_array($row['user'], $answered_data)) {
  107. echo '<a href="reporting.php?action=userreport&amp;survey_id='.$survey_id.'&amp;user='.$row['user'].'">'.get_lang('ViewAnswers').'</a>';
  108. } else {
  109. echo '-';
  110. }
  111. echo ' </td>';
  112. echo '</tr>';
  113. }
  114. }
  115. // Closing the table
  116. echo '</table>';
  117. // Footer
  118. Display :: display_footer();