gradebook_result.class.php 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. <?php
  2. /* For licensing terms, see /license.txt */
  3. /**
  4. * Gradebook results class
  5. * @author Yannick Warnier
  6. * @package chamilo.gradebook
  7. */
  8. class GradeBookResult
  9. {
  10. private $gradebook_list = array(); //stores the list of exercises
  11. private $results = array(); //stores the results
  12. /**
  13. * constructor of the class
  14. */
  15. public function __construct($get_questions = false, $get_answers = false)
  16. {
  17. }
  18. /**
  19. * Exports the complete report as a CSV file
  20. * @param string Document path inside the document tool
  21. * @param integer Optional user ID
  22. * @param boolean Whether to include user fields or not
  23. * @return boolean False on error
  24. */
  25. public function exportCompleteReportCSV($dato)
  26. {
  27. $filename = 'gradebook_results_'.gmdate('YmdGis').'.csv';
  28. if (!empty($user_id)) {
  29. $filename = 'gradebook_results_user_'.$user_id.'_'.gmdate('YmdGis').'.csv';
  30. }
  31. $data = '';
  32. //build the results
  33. //titles
  34. foreach ($dato[0] as $header_col) {
  35. if (!empty($header_col)) {
  36. $data .= str_replace("\r\n", ' ', api_html_entity_decode(strip_tags($header_col))).';';
  37. }
  38. }
  39. $data .= "\r\n";
  40. $cant_students = count($dato[1]);
  41. for ($i = 0; $i < $cant_students; $i++) {
  42. $column = 0;
  43. foreach ($dato[1][$i] as $col_name) {
  44. $data .= str_replace("\r\n", ' ', api_html_entity_decode(strip_tags($col_name))).';';
  45. }
  46. $data .= "\r\n";
  47. }
  48. //output the results
  49. $len = strlen($data);
  50. header('Content-type: application/octet-stream');
  51. header('Content-Type: application/force-download');
  52. header('Content-length: '.$len);
  53. if (preg_match("/MSIE 5.5/", $_SERVER['HTTP_USER_AGENT'])) {
  54. header('Content-Disposition: filename= '.$filename);
  55. } else {
  56. header('Content-Disposition: attachment; filename= '.$filename);
  57. } if (strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE')) {
  58. header('Pragma: ');
  59. header('Cache-Control: ');
  60. header('Cache-Control: public'); // IE cannot download from sessions without a cache
  61. }
  62. header('Content-Description: '.$filename);
  63. header('Content-transfer-encoding: binary');
  64. echo $data;
  65. return true;
  66. }
  67. /**
  68. * Exports the complete report as an XLS file
  69. * @return boolean|null False on error
  70. */
  71. public function exportCompleteReportXLS($data)
  72. {
  73. $filename = 'gradebook-results-'.api_get_local_time().'.xlsx';
  74. $spreadsheet = new PHPExcel();
  75. $spreadsheet->setActiveSheetIndex(0);
  76. $worksheet = $spreadsheet->getActiveSheet();
  77. $line = 0;
  78. $column = 1;
  79. //headers
  80. foreach ($data[0] as $header_col) {
  81. $worksheet->SetCellValueByColumnAndRow($line, $column, html_entity_decode(strip_tags($header_col)));
  82. $column++;
  83. }
  84. $line++;
  85. $cant_students = count($data[1]);
  86. for ($i = 0; $i < $cant_students; $i++) {
  87. $column = 0;
  88. foreach ($data[1][$i] as $col_name) {
  89. $worksheet->SetCellValueByColumnAndRow(
  90. $line,
  91. $column,
  92. html_entity_decode(strip_tags($col_name))
  93. );
  94. $column++;
  95. }
  96. $line++;
  97. }
  98. $file = api_get_path(SYS_ARCHIVE_PATH).api_replace_dangerous_char($filename);
  99. $writer = new PHPExcel_Writer_Excel2007($spreadsheet);
  100. $writer->save($file);
  101. DocumentManager::file_send_for_download($file, true, $filename);
  102. exit;
  103. }
  104. /**
  105. * Exports the complete report as a DOCX file
  106. * @param $data The table data
  107. * @return bool
  108. */
  109. public function exportCompleteReportDOC($data)
  110. {
  111. $filename = 'gradebook_results_'.api_get_local_time().'.docx';
  112. $doc = new \PhpOffice\PhpWord\PhpWord();
  113. $section = $doc->addSection(['orientation' => 'landscape']);
  114. $table = $section->addTable();
  115. $table->addRow();
  116. for ($i = 0; $i < count($data[0]); $i++) {
  117. $table->addCell(1750)->addText(strip_tags($data[0][$i]));
  118. }
  119. foreach ($data[1] as $dataLine) {
  120. $table->addRow();
  121. for ($i = 0; $i < count($dataLine); $i++) {
  122. $table->addCell(1750)->addText(strip_tags($dataLine[$i]));
  123. }
  124. }
  125. $file = api_get_path(SYS_ARCHIVE_PATH).api_replace_dangerous_char($filename);
  126. $doc->save($file, 'Word2007');
  127. DocumentManager::file_send_for_download($file, true, $filename);
  128. return true;
  129. }
  130. }