exercise_history.php 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. <?php
  2. /* For licensing terms, see /license.txt */
  3. /**
  4. * Exercise list: This script shows the list of exercises for administrators and students.
  5. * @package chamilo.exercise
  6. * @author Olivier Brouckaert, original author
  7. * @author Denes Nagy, HotPotatoes integration
  8. * @author Wolfgang Schneider, code/html cleanup
  9. */
  10. /**
  11. * Code
  12. */
  13. /**
  14. * name of the language file that needs to be included
  15. */
  16. $language_file='exercice';
  17. require_once '../inc/global.inc.php';
  18. $urlMainExercise = api_get_path(WEB_CODE_PATH).'exercice/';
  19. $this_section=SECTION_COURSES;
  20. api_protect_course_script(true);
  21. $show = (isset($_GET['show']) && $_GET['show'] == 'result')?'result':'test'; // moved down to fix bug: http://www.dokeos.com/forum/viewtopic.php?p=18609#18609
  22. $is_allowedToEdit = api_is_allowed_to_edit(null,true);
  23. $is_tutor = api_is_allowed_to_edit(true);
  24. if (!$is_allowedToEdit){
  25. header('Location: '.$urlMainExercise.'exercice.php?cidReq='.Security::remove_XSS($_GET['cidReq']));
  26. exit;
  27. }
  28. $interbreadcrumb[]= array ('url' => 'exercise_report.php', 'name' => get_lang('Exercices'));
  29. $interbreadcrumb[]= array ('url' => 'exercise_report.php?filter=2','name' => get_lang('StudentScore'));
  30. $interbreadcrumb[]= array ('url' => 'exercise_history.php?exe_id='.intval($_GET['exe_id']), 'name' => get_lang('Details'));
  31. $TBL_USER = Database::get_main_table(TABLE_MAIN_USER);
  32. $TBL_EXERCICES = Database::get_course_table(TABLE_QUIZ_TEST);
  33. $TBL_EXERCICES_QUESTION = Database::get_course_table(TABLE_QUIZ_QUESTION);
  34. $TBL_TRACK_EXERCICES = Database::get_main_table(TABLE_STATISTIC_TRACK_E_EXERCICES);
  35. $TBL_TRACK_ATTEMPT_RECORDING= Database::get_main_table(TABLE_STATISTIC_TRACK_E_ATTEMPT_RECORDING);
  36. Display::display_header($nameTools,get_lang('Exercise'));
  37. if (isset($_GET['message'])) {
  38. if (in_array($_GET['message'], array('ExerciseEdited'))) {
  39. $my_message_history=Security::remove_XSS($_GET['message']);
  40. Display::display_confirmation_message(get_lang($my_message_history));
  41. }
  42. }
  43. echo '<div class="actions">';
  44. echo '<a href="exercise_report.php?' . api_get_cidreq() . '&filter=2">' . Display :: return_icon('back.png', get_lang('BackToResultList'),'',ICON_SIZE_MEDIUM).'</a>';
  45. echo '</div>';
  46. ?>
  47. <table class="data_table">
  48. <tr class="row_odd">
  49. <th><?php echo get_lang('Question'); ?></th>
  50. <th width="50px"><?php echo get_lang('Value'); ?></th>
  51. <th><?php echo get_lang('Feedback'); ?></th>
  52. <th><?php echo get_lang('Author'); ?></th>
  53. <th width="160px"><?php echo get_lang('Date'); ?></th>
  54. </tr>
  55. <?php
  56. $sql = "SELECT *, quiz_question.question, firstname, lastname
  57. FROM $TBL_TRACK_ATTEMPT_RECORDING t, $TBL_USER, $TBL_EXERCICES_QUESTION quiz_question
  58. WHERE quiz_question.id = question_id AND
  59. user_id = author AND
  60. exe_id = '".(int)$_GET['exe_id']."'
  61. ORDER BY position";
  62. $query = Database::query($sql);
  63. while($row = Database::fetch_array($query)){
  64. echo '<tr';
  65. if($i%2==0) echo 'class="row_odd"'; else echo 'class="row_even"';
  66. echo '>';
  67. echo '<td>'.$row['question'].'</td>';
  68. echo '<td>'.$row['marks'].'</td>';
  69. if(!empty($row['teacher_comment'])){
  70. echo '<td>'.$row['teacher_comment'].'</td>';
  71. } else {
  72. echo '<td>'.get_lang('WithoutComment').'</td>';
  73. }
  74. echo '<td>'.(empty($row['firstname']) && empty($row['lastname']) ? '<i>'.get_lang('OriginalValue').'</i>' : api_get_person_name($row['firstname'], $row['lastname'])).'</td>';
  75. echo '<td>'.api_convert_and_format_date($row['insert_date'], DATE_TIME_FORMAT_LONG).'</td>';
  76. echo '</tr>';
  77. }
  78. echo '</table>';
  79. Display::display_footer();