work_list_all.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453
  1. <?php
  2. /* For licensing terms, see /license.txt */
  3. require_once __DIR__.'/../inc/global.inc.php';
  4. $current_course_tool = TOOL_STUDENTPUBLICATION;
  5. api_protect_course_script(true);
  6. // Including necessary files
  7. require_once 'work.lib.php';
  8. $this_section = SECTION_COURSES;
  9. $workId = isset($_GET['id']) ? (int) $_GET['id'] : null;
  10. $is_allowed_to_edit = api_is_allowed_to_edit() || api_is_coach();
  11. if (empty($workId)) {
  12. api_not_allowed(true);
  13. }
  14. $my_folder_data = get_work_data_by_id($workId);
  15. if (empty($my_folder_data)) {
  16. api_not_allowed(true);
  17. }
  18. $work_data = get_work_assignment_by_id($workId);
  19. $isDrhOfCourse = CourseManager::isUserSubscribedInCourseAsDrh(
  20. api_get_user_id(),
  21. api_get_course_info()
  22. );
  23. if (!($is_allowed_to_edit || $isDrhOfCourse)) {
  24. api_not_allowed(true);
  25. }
  26. $tool_name = get_lang('StudentPublications');
  27. $group_id = api_get_group_id();
  28. $courseInfo = api_get_course_info();
  29. $courseCode = $courseInfo['code'];
  30. $sessionId = api_get_session_id();
  31. $htmlHeadXtra[] = api_get_jqgrid_js();
  32. $user_id = api_get_user_id();
  33. if (!empty($group_id)) {
  34. $group_properties = GroupManager::get_group_properties($group_id);
  35. $show_work = false;
  36. if (api_is_allowed_to_edit(false, true)) {
  37. $show_work = true;
  38. } else {
  39. // you are not a teacher
  40. $show_work = GroupManager::user_has_access(
  41. $user_id,
  42. $group_properties['iid'],
  43. GroupManager::GROUP_TOOL_WORK
  44. );
  45. }
  46. if (!$show_work) {
  47. api_not_allowed();
  48. }
  49. $interbreadcrumb[] = [
  50. 'url' => api_get_path(WEB_CODE_PATH).'group/group.php?'.api_get_cidreq(),
  51. 'name' => get_lang('Groups'),
  52. ];
  53. $interbreadcrumb[] = [
  54. 'url' => api_get_path(WEB_CODE_PATH).'group/group_space.php?'.api_get_cidreq(),
  55. 'name' => get_lang('GroupSpace').' '.$group_properties['name'],
  56. ];
  57. }
  58. $interbreadcrumb[] = [
  59. 'url' => api_get_path(WEB_CODE_PATH).'work/work.php?'.api_get_cidreq(),
  60. 'name' => get_lang('StudentPublications'),
  61. ];
  62. $interbreadcrumb[] = [
  63. 'url' => api_get_path(WEB_CODE_PATH).'work/work_list_all.php?'.api_get_cidreq().'&id='.$workId,
  64. 'name' => $my_folder_data['title'],
  65. ];
  66. $action = isset($_REQUEST['action']) ? $_REQUEST['action'] : null;
  67. $itemId = isset($_REQUEST['item_id']) ? (int) $_REQUEST['item_id'] : null;
  68. switch ($action) {
  69. case 'export_to_doc':
  70. if ($is_allowed_to_edit) {
  71. if (!empty($itemId)) {
  72. $work = get_work_data_by_id($itemId);
  73. if (!empty($work)) {
  74. Export::htmlToOdt($work['description'], $work['title']);
  75. }
  76. }
  77. }
  78. break;
  79. case 'delete':
  80. /* Delete document */
  81. if ($itemId) {
  82. $fileDeleted = deleteWorkItem($itemId, $courseInfo);
  83. if (!$fileDeleted) {
  84. Display::addFlash(
  85. Display::return_message(get_lang('YouAreNotAllowedToDeleteThisDocument'), 'error')
  86. );
  87. } else {
  88. Display::addFlash(
  89. Display::return_message(get_lang('TheDocumentHasBeenDeleted'), 'confirmation')
  90. );
  91. }
  92. }
  93. break;
  94. case 'delete_correction':
  95. $result = get_work_user_list(null, null, null, null, $workId);
  96. if ($result) {
  97. foreach ($result as $item) {
  98. $workToDelete = get_work_data_by_id($item['id']);
  99. deleteCorrection($courseInfo, $workToDelete);
  100. }
  101. Display::addFlash(
  102. Display::return_message(get_lang('Deleted'), 'confirmation')
  103. );
  104. }
  105. header('Location: '.api_get_self().'?'.api_get_cidreq().'&id='.$workId);
  106. exit;
  107. break;
  108. case 'make_visible':
  109. /* Visible */
  110. if ($is_allowed_to_edit) {
  111. if (!empty($itemId)) {
  112. if (isset($itemId) && $itemId == 'all') {
  113. } else {
  114. makeVisible($itemId, $courseInfo);
  115. Display::addFlash(
  116. Display::return_message(get_lang('FileVisible'), 'confirmation')
  117. );
  118. }
  119. }
  120. }
  121. break;
  122. case 'make_invisible':
  123. /* Invisible */
  124. if (!empty($itemId)) {
  125. if (isset($itemId) && $itemId == 'all') {
  126. } else {
  127. makeInvisible($itemId, $courseInfo);
  128. Display::addFlash(
  129. Display::return_message(get_lang('FileInvisible'), 'confirmation')
  130. );
  131. }
  132. }
  133. break;
  134. case 'export_pdf':
  135. exportAllStudentWorkFromPublication(
  136. $workId,
  137. $courseInfo,
  138. $sessionId,
  139. 'pdf'
  140. );
  141. break;
  142. }
  143. $htmlHeadXtra[] = api_get_jquery_libraries_js(['jquery-upload']);
  144. Display::display_header(null);
  145. $documentsAddedInWork = getAllDocumentsFromWorkToString($workId, $courseInfo);
  146. $actionsLeft = '<a href="'.api_get_path(WEB_CODE_PATH).'work/work.php?'.api_get_cidreq().'">'.
  147. Display::return_icon('back.png', get_lang('BackToWorksList'), '', ICON_SIZE_MEDIUM).'</a>';
  148. if (api_is_allowed_to_session_edit(false, true) && !empty($workId) && !$isDrhOfCourse) {
  149. $blockAddDocuments = api_get_configuration_value('block_student_publication_add_documents');
  150. if (!$blockAddDocuments) {
  151. $actionsLeft .= '<a href="'.api_get_path(WEB_CODE_PATH).'work/add_document.php?'.api_get_cidreq().'&id='.$workId.'">';
  152. $actionsLeft .= Display::return_icon('new_document.png', get_lang('AddDocument'), '', ICON_SIZE_MEDIUM).'</a>';
  153. }
  154. $actionsLeft .= '<a href="'.api_get_path(WEB_CODE_PATH).'work/add_user.php?'.api_get_cidreq().'&id='.$workId.'">';
  155. $actionsLeft .= Display::return_icon('addworkuser.png', get_lang('AddUsers'), '', ICON_SIZE_MEDIUM).'</a>';
  156. $actionsLeft .= '<a href="'.api_get_path(WEB_CODE_PATH).'work/work_list_all.php?'.api_get_cidreq().'&id='.$workId.'&action=export_pdf">';
  157. $actionsLeft .= Display::return_icon('pdf.png', get_lang('Export'), '', ICON_SIZE_MEDIUM).'</a>';
  158. $display_output = '<a href="'.api_get_path(WEB_CODE_PATH).'work/work_missing.php?'.api_get_cidreq().'&amp;id='.$workId.'&amp;list=without">'.
  159. Display::return_icon('exercice_uncheck.png', get_lang('ViewUsersWithoutTask'), '', ICON_SIZE_MEDIUM)."</a>";
  160. $editLink = '<a href="'.api_get_path(WEB_CODE_PATH).'work/edit_work.php?'.api_get_cidreq().'&id='.$workId.'">';
  161. $editLink .= Display::return_icon('edit.png', get_lang('Edit'), '', ICON_SIZE_MEDIUM).'</a>';
  162. $blockEdition = api_get_configuration_value('block_student_publication_edition');
  163. if ($blockEdition && !api_is_platform_admin()) {
  164. $editLink = '';
  165. }
  166. $actionsLeft .= $editLink;
  167. $count = get_count_work($workId);
  168. if ($count > 0) {
  169. $display_output .= '<a class="btn-toolbar" href="downloadfolder.inc.php?id='.$workId.'&'.api_get_cidreq().'">'.
  170. Display::return_icon('save_pack.png', get_lang('DownloadTasksPackage'), null, ICON_SIZE_MEDIUM).' '.get_lang('DownloadTasksPackage').'</a>';
  171. }
  172. $actionsLeft .= $display_output;
  173. $url = api_get_path(WEB_CODE_PATH).'work/upload_corrections.php?'.api_get_cidreq().'&id='.$workId;
  174. $actionsLeft .= '<a class="btn-toolbar" href="'.$url.'">'.
  175. Display::return_icon('upload_package.png', get_lang('UploadCorrectionsPackage'), '', ICON_SIZE_MEDIUM).' '.get_lang('UploadCorrectionsPackage').'</a>';
  176. $url = api_get_path(WEB_CODE_PATH).'work/work_list_all.php?'.api_get_cidreq().'&id='.$workId.'&action=delete_correction';
  177. $actionsLeft .= Display::toolbarButton(get_lang('DeleteCorrections'), $url, 'remove', 'danger');
  178. }
  179. echo Display::toolbarAction('toolbar-worklist', [$actionsLeft]);
  180. if (!empty($my_folder_data['title'])) {
  181. echo Display::page_subheader($my_folder_data['title']);
  182. }
  183. if (!empty($my_folder_data['description'])) {
  184. $contentWork = Security::remove_XSS($my_folder_data['description']);
  185. $html = '';
  186. $html .= Display::panel($contentWork, get_lang('Description'));
  187. echo $html;
  188. }
  189. $check_qualification = (int) $my_folder_data['qualification'];
  190. $orderName = api_is_western_name_order() ? 'firstname' : 'lastname';
  191. if (!empty($work_data['enable_qualification']) &&
  192. !empty($check_qualification)
  193. ) {
  194. $type = 'simple';
  195. $columns = [
  196. get_lang('FullUserName'),
  197. get_lang('Title'),
  198. get_lang('Score'),
  199. get_lang('Date'),
  200. get_lang('Status'),
  201. get_lang('UploadCorrection'),
  202. get_lang('Actions'),
  203. ];
  204. $column_model = [
  205. [
  206. 'name' => 'fullname',
  207. 'index' => $orderName,
  208. 'width' => '30',
  209. 'align' => 'left',
  210. 'search' => 'true',
  211. ],
  212. [
  213. 'name' => 'title',
  214. 'index' => 'title',
  215. 'width' => '25',
  216. 'align' => 'left',
  217. 'search' => 'false',
  218. 'wrap_cell' => 'true',
  219. ],
  220. [
  221. 'name' => 'qualification',
  222. 'index' => 'qualification',
  223. 'width' => '15',
  224. 'align' => 'center',
  225. 'search' => 'true',
  226. ],
  227. [
  228. 'name' => 'sent_date',
  229. 'index' => 'sent_date',
  230. 'width' => '25',
  231. 'align' => 'left',
  232. 'search' => 'true',
  233. 'wrap_cell' => 'true',
  234. ],
  235. [
  236. 'name' => 'qualificator_id',
  237. 'index' => 'qualificator_id',
  238. 'width' => '20',
  239. 'align' => 'left',
  240. 'search' => 'true',
  241. ],
  242. [
  243. 'name' => 'correction',
  244. 'index' => 'correction',
  245. 'width' => '30',
  246. 'align' => 'left',
  247. 'search' => 'false',
  248. 'sortable' => 'false',
  249. 'title' => 'false',
  250. ],
  251. [
  252. 'name' => 'actions',
  253. 'index' => 'actions',
  254. 'width' => '25',
  255. 'align' => 'left',
  256. 'search' => 'false',
  257. 'sortable' => 'false',
  258. ],
  259. ];
  260. } else {
  261. $type = 'complex';
  262. $columns = [
  263. get_lang('FullUserName'),
  264. get_lang('Title'),
  265. get_lang('Feedback'),
  266. get_lang('Date'),
  267. get_lang('UploadCorrection'),
  268. get_lang('Actions'),
  269. ];
  270. $column_model = [
  271. [
  272. 'name' => 'fullname',
  273. 'index' => $orderName,
  274. 'width' => '35',
  275. 'align' => 'left',
  276. 'search' => 'true',
  277. ],
  278. [
  279. 'name' => 'title',
  280. 'index' => 'title',
  281. 'width' => '30',
  282. 'align' => 'left',
  283. 'search' => 'false',
  284. 'wrap_cell' => 'true',
  285. ],
  286. [
  287. 'name' => 'qualification',
  288. 'index' => 'qualification',
  289. 'width' => '20',
  290. 'align' => 'center',
  291. 'search' => 'true',
  292. ],
  293. [
  294. 'name' => 'sent_date',
  295. 'index' => 'sent_date',
  296. 'width' => '30',
  297. 'align' => 'left',
  298. 'search' => 'true',
  299. 'wrap_cell' => 'true',
  300. ],
  301. [
  302. 'name' => 'correction',
  303. 'index' => 'correction',
  304. 'width' => '40',
  305. 'align' => 'left',
  306. 'search' => 'false',
  307. 'sortable' => 'false',
  308. 'title' => 'false',
  309. ],
  310. [
  311. 'name' => 'actions',
  312. 'index' => 'actions',
  313. 'width' => '30',
  314. 'align' => 'left',
  315. 'search' => 'false',
  316. 'sortable' => 'false',
  317. //'wrap_cell' => 'true',
  318. ],
  319. ];
  320. }
  321. $extra_params = [
  322. 'autowidth' => 'true',
  323. 'height' => 'auto',
  324. 'sortname' => $orderName,
  325. 'sortable' => 'false',
  326. 'multiselect' => 'true',
  327. ];
  328. $url = api_get_path(WEB_AJAX_PATH).
  329. 'model.ajax.php?a=get_work_user_list_all&work_id='.$workId.'&type='.$type.'&'.api_get_cidreq();
  330. $workUrl = api_get_path(WEB_AJAX_PATH).'work.ajax.php?'.api_get_cidreq();
  331. $deleteUrl = $workUrl.'&a=delete_student_work';
  332. $showUrl = $workUrl.'&a=show_student_work';
  333. $hideUrl = $workUrl.'&a=hide_student_work';
  334. ?>
  335. <script>
  336. $(function() {
  337. <?php
  338. echo Display::grid_js('results', $url, $columns, $column_model, $extra_params);
  339. ?>
  340. $("#results").jqGrid(
  341. "navGrid",
  342. "#results_pager",
  343. { edit: false, add: false, search: false, del: true },
  344. { height:280, reloadAfterSubmit:false }, // edit options
  345. { height:280, reloadAfterSubmit:false }, // add options
  346. { reloadAfterSubmit:false, url: "<?php echo $deleteUrl; ?>" }, // del options
  347. { width:500 } // search options
  348. ).navButtonAdd('#results_pager', {
  349. caption:"<i class=\"fa fa-eye\" ></i>",
  350. buttonicon:"ui-icon-blank",
  351. onClickButton: function(a) {
  352. var userIdList = $("#results").jqGrid('getGridParam', 'selarrrow');
  353. if (userIdList.length) {
  354. $.ajax({
  355. type: "POST",
  356. url: "<?php echo $showUrl; ?>&item_list=" + userIdList,
  357. dataType: "json",
  358. success: function(data) {
  359. $('#results').trigger('reloadGrid');
  360. }
  361. });
  362. } else {
  363. alert("<?php echo addslashes(get_lang('SelectAnOption')); ?>");
  364. }
  365. },
  366. position:"last"
  367. }).navButtonAdd('#results_pager', {
  368. //caption:"<?php //echo addslashes(get_lang('SetVisible'));?>//",
  369. caption:"<i class=\"fa fa-eye-slash\" ></i>",
  370. buttonicon:"ui-icon-blank",
  371. onClickButton: function(a) {
  372. var userIdList = $("#results").jqGrid('getGridParam', 'selarrrow');
  373. if (userIdList.length) {
  374. $.ajax({
  375. type: "POST",
  376. url: "<?php echo $hideUrl; ?>&item_list=" + userIdList,
  377. dataType: "json",
  378. success: function(data) {
  379. $('#results').trigger('reloadGrid');
  380. }
  381. });
  382. } else {
  383. alert("<?php echo addslashes(get_lang('SelectAnOption')); ?>");
  384. }
  385. },
  386. position:"last"
  387. });
  388. });
  389. </script>
  390. <?php
  391. echo $documentsAddedInWork;
  392. $tableWork = Display::grid_html('results');
  393. echo workGetExtraFieldData($workId);
  394. echo Display::panel($tableWork);
  395. echo '<div class="list-work-results">';
  396. echo '<div class="panel panel-default">';
  397. echo '<div class="panel-body">';
  398. echo '<table style="display:none; width:100%" class="files data_table">
  399. <tr>
  400. <th>'.get_lang('FileName').'</th>
  401. <th>'.get_lang('Size').'</th>
  402. <th>'.get_lang('Status').'</th>
  403. </tr>
  404. </table>';
  405. echo '</div></div></div>';
  406. Display :: display_footer();