lp_list.php 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486
  1. <?php
  2. /* For licensing terms, see /license.txt */
  3. /**
  4. * This file was originally the copy of document.php, but many modifications happened since then ;
  5. * the direct file view is not any more needed, if the user uploads a SCORM zip file, a directory
  6. * will be automatically created for it, and the files will be uncompressed there for example ;
  7. *
  8. * @package chamilo.learnpath
  9. * @author Yannick Warnier <ywarnier@beeznest.org>
  10. */
  11. use \ChamiloSession as Session;
  12. $this_section = SECTION_COURSES;
  13. //@todo who turns on $lp_controller_touched?
  14. if (empty($lp_controller_touched) || $lp_controller_touched != 1) {
  15. header('location: lp_controller.php?action=list');
  16. }
  17. require_once 'back_compat.inc.php';
  18. $courseDir = api_get_course_path().'/scorm';
  19. $baseWordDir = $courseDir;
  20. require_once 'learnpathList.class.php';
  21. require_once 'learnpath.class.php';
  22. require_once 'learnpathItem.class.php';
  23. /**
  24. * Display initialisation and security checks
  25. */
  26. // Extra javascript functions for in html head:
  27. $htmlHeadXtra[] =
  28. "<script>
  29. function confirmation(name) {
  30. if (confirm(\" ".trim(get_lang('AreYouSureToDelete'))." \"+name+\"?\"))
  31. {return true;}
  32. else
  33. {return false;}
  34. }
  35. </script>";
  36. $nameTools = get_lang('LearningPaths');
  37. event_access_tool(TOOL_LEARNPATH);
  38. api_protect_course_script();
  39. //if (!$is_allowed_in_course) api_not_allowed();
  40. /**
  41. * Display
  42. */
  43. /* Require the search widget and prepare the header with its stuff. */
  44. if (api_get_setting('search_enabled') == 'true') {
  45. require api_get_path(LIBRARY_PATH).'search/search_widget.php';
  46. search_widget_prepare($htmlHeadXtra);
  47. }
  48. Display::display_header($nameTools, 'Path');
  49. $current_session = api_get_session_id();
  50. /* Introduction section (editable by course admins) */
  51. Display::display_introduction_section(TOOL_LEARNPATH, array(
  52. 'CreateDocumentWebDir' => api_get_path(WEB_COURSE_PATH).api_get_course_path().'/document/',
  53. 'CreateDocumentDir' => '../../courses/'.api_get_course_path().'/document/',
  54. 'BaseHref' => api_get_path(WEB_COURSE_PATH).api_get_course_path().'/'
  55. ));
  56. $is_allowed_to_edit = api_is_allowed_to_edit(null, true);
  57. if ($is_allowed_to_edit) {
  58. if (!empty($dialog_box)) {
  59. switch ($_GET['dialogtype']) {
  60. case 'confirmation':
  61. Display::display_confirmation_message($dialog_box);
  62. break;
  63. case 'error':
  64. Display::display_error_message($dialog_box);
  65. break;
  66. case 'warning':
  67. Display::display_warning_message($dialog_box);
  68. break;
  69. default:
  70. Display::display_normal_message($dialog_box);
  71. break;
  72. }
  73. }
  74. if (api_failure::get_last_failure()) {
  75. Display::display_normal_message(api_failure::get_last_failure());
  76. }
  77. echo '<div class="actions">';
  78. echo '<a href="'.api_get_self().'?'.api_get_cidreq().'&action=add_lp">'.Display::return_icon('new_learnpath.png', get_lang('LearnpathAddLearnpath'), '', ICON_SIZE_MEDIUM).'</a>'.
  79. str_repeat('&nbsp;', 3).
  80. '<a href="../upload/index.php?'.api_get_cidreq().'&curdirpath=/&tool='.TOOL_LEARNPATH.'">'.Display::return_icon('import_scorm.png', get_lang('UploadScorm'), '', ICON_SIZE_MEDIUM).'</a>';
  81. if (api_get_setting('service_ppt2lp', 'active') == 'true') {
  82. echo str_repeat('&nbsp;', 3).'<a href="../upload/upload_ppt.php?'.api_get_cidreq().'&curdirpath=/&tool='.TOOL_LEARNPATH.'">
  83. '.Display::return_icon('import_powerpoint.png', get_lang('PowerPointConvert'), '', ICON_SIZE_MEDIUM).'</a>';
  84. }
  85. echo '</div>';
  86. }
  87. $token = Security::get_token();
  88. /* DISPLAY SCORM LIST */
  89. $userId = api_get_user_id();
  90. $userInfo = api_get_user_info();
  91. $list = new LearnpathList($userId);
  92. $flat_list = $list->get_flat_list();
  93. if (!empty($flat_list)) {
  94. echo '<table class="data_table">';
  95. echo '<tr>';
  96. if ($is_allowed_to_edit) {
  97. echo '<th width="35%">'.get_lang('Title').'</th>';
  98. echo '<th>'.get_lang('PublicationDate').'</th>';
  99. echo '<th>'.get_lang('ExpirationDate').'</th>';
  100. echo '<th>'.get_lang('Progress')."</th>";
  101. echo '<th width="300px">'.get_lang('AuthoringOptions')."</th>";
  102. } else {
  103. echo '<th width="50%">'.get_lang('Title').'</th>';
  104. echo '<th>'.get_lang('Progress')."</th>";
  105. echo '<th>'.get_lang('Actions')."</th>";
  106. }
  107. echo '</tr>';
  108. $test_mode = api_get_setting('server_type');
  109. $max = count($flat_list);
  110. $counter = 0;
  111. $current = 0;
  112. $autolunch_exists = false;
  113. foreach ($flat_list as $id => $details) {
  114. // Validation when belongs to a session.
  115. $session_img = api_get_session_image($details['lp_session'], $userInfo['status']);
  116. if (!$is_allowed_to_edit && $details['lp_visibility'] == 0) {
  117. // This is a student and this path is invisible, skip.
  118. continue;
  119. }
  120. // Check if the learnpath is visible for student.
  121. if (!$is_allowed_to_edit && !learnpath::is_lp_visible_for_student($id, $userId)) {
  122. continue;
  123. }
  124. $start_time = $end_time = '';
  125. if (!$is_allowed_to_edit) {
  126. $time_limits = false;
  127. //This is an old LP (from a migration 1.8.7) so we do nothing
  128. if ((empty($details['created_on']) || $details['created_on'] == '0000-00-00 00:00:00') &&
  129. (empty($details['modified_on']) || $details['modified_on'] == '0000-00-00 00:00:00')
  130. ) {
  131. $time_limits = false;
  132. }
  133. //Checking if expired_on is ON
  134. if ($details['expired_on'] != '' && $details['expired_on'] != '0000-00-00 00:00:00') {
  135. $time_limits = true;
  136. }
  137. if ($time_limits) {
  138. // Check if start time
  139. if (!empty($details['publicated_on']) && $details['publicated_on'] != '0000-00-00 00:00:00' &&
  140. !empty($details['expired_on']) && $details['expired_on'] != '0000-00-00 00:00:00') {
  141. $start_time = api_strtotime($details['publicated_on'], 'UTC');
  142. $end_time = api_strtotime($details['expired_on'], 'UTC');
  143. $now = time();
  144. $is_actived_time = false;
  145. if ($now > $start_time && $end_time > $now) {
  146. $is_actived_time = true;
  147. }
  148. if (!$is_actived_time) {
  149. continue;
  150. }
  151. }
  152. }
  153. $start_time = $end_time = '';
  154. } else {
  155. if (!empty($details['publicated_on'])) {
  156. $start_time = api_convert_and_format_date($details['publicated_on'], DATE_TIME_FORMAT_LONG);
  157. }
  158. if (!empty($details['expired_on'])) {
  159. $end_time = api_convert_and_format_date($details['expired_on'], DATE_TIME_FORMAT_LONG);
  160. }
  161. }
  162. $counter++;
  163. if (($counter % 2) == 0) {
  164. $oddclass = 'row_odd';
  165. } else {
  166. $oddclass = 'row_even';
  167. }
  168. $url_start_lp = 'lp_controller.php?'.api_get_cidreq().'&action=view&lp_id='.$id;
  169. $name = Security::remove_XSS($details['lp_name']);
  170. $extra = null;
  171. if ($is_allowed_to_edit) {
  172. $url_start_lp .= '&isStudentView=true';
  173. $studentVisibility = learnpath::is_lp_visible_for_student($id, $userId);
  174. $dsp_desc = '<em>'.$details['lp_maker'].'</em> '.( $studentVisibility ? '' : ' - ('.get_lang('LPNotVisibleToStudent').')');
  175. $extra = '<div class ="lp_content_type_label">'.$dsp_desc.'</div>';
  176. }
  177. $my_title = $name;
  178. $icon_learnpath = Display::return_icon('learnpath.png', get_lang('LPName'), '', ICON_SIZE_SMALL);
  179. if ($details['lp_visibility'] == 0) {
  180. $my_title = Display::tag('font', $name, array('class' => 'invisible'));
  181. $icon_learnpath = Display::return_icon('learnpath_na.png', get_lang('LPName'), '', ICON_SIZE_SMALL);
  182. }
  183. $dsp_line = '<tr align="center" class="'.$oddclass.'">'.
  184. '<td align="left" valign="top">'.$icon_learnpath.'
  185. <a href="'.$url_start_lp.'">'.$my_title.'</a>'.$session_img.$extra."</td>";
  186. $dsp_desc = '';
  187. $dsp_export = '';
  188. $dsp_build = '';
  189. $dsp_delete = '';
  190. $dsp_visible = '';
  191. $dsp_default_view = '';
  192. $dsp_debug = '';
  193. $dsp_order = '';
  194. $progress = learnpath::getProgress(
  195. $id,
  196. $userId,
  197. api_get_course_int_id(),
  198. api_get_session_id()
  199. );
  200. if ($is_allowed_to_edit) {
  201. $dsp_progress = '<td><center>'.$progress.'</center></td>';
  202. } else {
  203. $dsp_progress = '<td>'.learnpath::get_progress_bar($progress, '%').'</td>';
  204. }
  205. $dsp_edit = '<td class="td_actions">';
  206. $dsp_edit_close = '</td>';
  207. $token_parameter = "&sec_token=$token";
  208. $dsp_edit_lp = null;
  209. $dsp_publish = null;
  210. $dsp_reinit = null;
  211. $dsp_disk = null;
  212. $copy = null;
  213. $lp_auto_lunch_icon = null;
  214. if ($is_allowed_to_edit) {
  215. // EDIT LP
  216. if ($current_session == $details['lp_session']) {
  217. $dsp_edit_lp = '<a href="lp_controller.php?'.api_get_cidreq().'&action=edit&lp_id='.$id.'">'.
  218. Display::return_icon('settings.png', get_lang('CourseSettings'), '', ICON_SIZE_SMALL).'</a>';
  219. } else {
  220. $dsp_edit_lp = Display::return_icon('settings_na.png', get_lang('CourseSettings'), '', ICON_SIZE_SMALL);
  221. }
  222. // BUILD
  223. if ($current_session == $details['lp_session']) {
  224. if ($details['lp_type'] == 1 || $details['lp_type'] == 2) {
  225. $dsp_build = '<a href="lp_controller.php?'.api_get_cidreq().'&amp;action=add_item&amp;type=step&amp;lp_id='.$id.'">'.
  226. Display::return_icon('edit.png', get_lang('LearnpathEditLearnpath'), '', ICON_SIZE_SMALL).'</a>';
  227. } else {
  228. $dsp_build = Display::return_icon('edit_na.png', get_lang('LearnpathEditLearnpath'), '', ICON_SIZE_SMALL);
  229. }
  230. } else {
  231. $dsp_build = Display::return_icon('edit_na.png', get_lang('LearnpathEditLearnpath'), '', ICON_SIZE_SMALL);
  232. }
  233. /* VISIBILITY COMMAND */
  234. /* Session test not necessary if we want to show base course learning
  235. paths inside the session.
  236. See http://support.chamilo.org/projects/chamilo-18/wiki/Tools_and_sessions).
  237. */
  238. if ($details['lp_visibility'] == 0) {
  239. $dsp_visible = "<a href=\"".api_get_self()."?".api_get_cidreq()."&lp_id=$id&action=toggle_visible&new_status=1\">".Display::return_icon('invisible.png', get_lang('Show'), '', ICON_SIZE_SMALL)."</a>";
  240. } else {
  241. $dsp_visible = "<a href='".api_get_self()."?".api_get_cidreq()."&lp_id=$id&action=toggle_visible&new_status=0'>".Display::return_icon('visible.png', get_lang('Hide'), '', ICON_SIZE_SMALL)."</a>";
  242. }
  243. /* PUBLISH COMMAND */
  244. if ($current_session == $details['lp_session']) {
  245. if ($details['lp_published'] == "i") {
  246. $dsp_publish = "<a href=\"".api_get_self()."?".api_get_cidreq()."&lp_id=$id&action=toggle_publish&new_status=v\">".
  247. Display::return_icon('lp_publish_na.png', get_lang('LearnpathPublish'), '', ICON_SIZE_SMALL)."</a>";
  248. } else {
  249. $dsp_publish = "<a href='".api_get_self()."?".api_get_cidreq()."&lp_id=$id&action=toggle_publish&new_status=i'>".Display::return_icon('lp_publish.png', get_lang('LearnpathDoNotPublish'), '', ICON_SIZE_SMALL)."</a>";
  250. }
  251. } else {
  252. $dsp_publish = Display::return_icon('lp_publish_na.png', get_lang('LearnpathDoNotPublish'), '', ICON_SIZE_SMALL);
  253. }
  254. /* MULTIPLE ATTEMPTS OR SERIOUS GAME MODE
  255. SERIOUSGAME MODE is a special mode where :
  256. * If a user exits the learning path before finishing it, he comes back where he left next time he tries
  257. * When lp status is completed, user can still modify the attempt (adds/time change score, and browse it)
  258. * It is thus a mix betwenn multiple attempt and mono attempt
  259. */
  260. if ($current_session == $details['lp_session']) {
  261. if ($details['seriousgame_mode'] == 1 && $details['lp_prevent_reinit'] == 1) { //seriousgame mode | next = single
  262. $dsp_reinit = '<a href="lp_controller.php?'.api_get_cidreq().'&action=switch_attempt_mode&lp_id='.$id.'">'.
  263. Display::return_icon('reload.png', get_lang('PreventMultipleAttempts'), '', ICON_SIZE_SMALL).
  264. '</a>';
  265. }
  266. if ($details['seriousgame_mode'] == 0 && $details['lp_prevent_reinit'] == 1) { //single mode | next = multiple
  267. $dsp_reinit = '<a href="lp_controller.php?'.api_get_cidreq().'&action=switch_attempt_mode&lp_id='.$id.'">'.
  268. Display::return_icon('reload_na.png', get_lang('AllowMultipleAttempts'), '', ICON_SIZE_SMALL).
  269. '</a>';
  270. }
  271. if ($details['seriousgame_mode'] == 0 && $details['lp_prevent_reinit'] == 0) { //multiple mode | next = seriousgame
  272. $dsp_reinit = '<a href="lp_controller.php?'.api_get_cidreq().'&action=switch_attempt_mode&lp_id='.$id.'">'.Display::return_icon('reload.png', get_lang('AllowMultipleAttempts'), '', ICON_SIZE_SMALL).
  273. '</a>';
  274. }
  275. } else {
  276. $dsp_reinit = Display::return_icon('reload_na.png', get_lang('AllowMultipleAttempts'), '', ICON_SIZE_SMALL);
  277. }
  278. /* SCREEN LP VIEW */
  279. if ($current_session == $details['lp_session']) {
  280. switch ($details['lp_view_mode']) {
  281. case 'fullscreen':
  282. $dsp_default_view = '<a href="lp_controller.php?'.api_get_cidreq().'&action=switch_view_mode&lp_id='.$id.$token_parameter.'">'.
  283. Display::return_icon('view_fullscreen.png', get_lang('ViewModeFullScreen'), '', ICON_SIZE_SMALL).'</a>';
  284. break;
  285. case 'embedded':
  286. $dsp_default_view = '<a href="lp_controller.php?'.api_get_cidreq().'&action=switch_view_mode&lp_id='.$id.$token_parameter.'">'.
  287. Display::return_icon('view_left_right.png', get_lang('ViewModeEmbedded'), '', ICON_SIZE_SMALL).'</a>';
  288. break;
  289. case 'embedframe':
  290. $dsp_default_view = '<a href="lp_controller.php?'.api_get_cidreq().'&action=switch_view_mode&lp_id='.$id.$token_parameter.'">'.
  291. Display::return_icon('view_nofullscreen.png', get_lang('ViewModeEmbedFrame'), '', ICON_SIZE_SMALL).'</a>';
  292. break;
  293. case 'impress':
  294. $dsp_default_view = '<a href="lp_controller.php?'.api_get_cidreq().'&action=switch_view_mode&lp_id='.$id.$token_parameter.'">'.
  295. Display::return_icon('window_list_slide.png', get_lang('ViewModeImpress'), '', ICON_SIZE_SMALL).'</a>';
  296. break;
  297. }
  298. } else {
  299. if ($details['lp_view_mode'] == 'fullscreen') {
  300. $dsp_default_view = Display::return_icon('view_fullscreen_na.png', get_lang('ViewModeEmbedded'), '', ICON_SIZE_SMALL);
  301. } else {
  302. $dsp_default_view = Display::return_icon('view_left_right_na.png', get_lang('ViewModeEmbedded'), '', ICON_SIZE_SMALL);
  303. }
  304. }
  305. /* DEBUG */
  306. if ($test_mode == 'test' or api_is_platform_admin()) {
  307. if ($details['lp_scorm_debug'] == 1) {
  308. $dsp_debug = '<a href="lp_controller.php?'.api_get_cidreq().'&action=switch_scorm_debug&lp_id='.$id.'">'.
  309. Display::return_icon('bug.png', get_lang('HideDebug'), '', ICON_SIZE_SMALL).'</a>';
  310. } else {
  311. $dsp_debug = '<a href="lp_controller.php?'.api_get_cidreq().'&action=switch_scorm_debug&lp_id='.$id.'">'.
  312. Display::return_icon('bug_na.png', get_lang('ShowDebug'), '', ICON_SIZE_SMALL).'</a>';
  313. }
  314. }
  315. /* Export */
  316. if ($details['lp_type'] == 1) {
  317. $dsp_disk = Display::url(
  318. Display::return_icon('cd.gif', get_lang('Export'), array(), ICON_SIZE_SMALL),
  319. api_get_self()."?".api_get_cidreq()."&action=export&lp_id=$id"
  320. );
  321. } elseif ($details['lp_type'] == 2) {
  322. $dsp_disk = Display::url(
  323. Display::return_icon('cd.gif', get_lang('Export'), array(), ICON_SIZE_SMALL),
  324. api_get_self()."?".api_get_cidreq()."&action=export&lp_id=$id&export_name=".replace_dangerous_char($name, 'strict').".zip"
  325. );
  326. } else {
  327. $dsp_disk = Display::return_icon('cd_gray.gif', get_lang('Export'), array(), ICON_SIZE_SMALL);
  328. }
  329. // Copy
  330. $copy = Display::url(
  331. Display::return_icon(
  332. 'cd_copy.png',
  333. get_lang('Copy'),
  334. array(),
  335. ICON_SIZE_SMALL
  336. ),
  337. api_get_self() . "?" . api_get_cidreq() . "&action=copy&lp_id=$id"
  338. );
  339. /* Auto Lunch LP code */
  340. if (api_get_course_setting('enable_lp_auto_launch') == 1) {
  341. if ($details['autolaunch'] == 1 && $autolunch_exists == false) {
  342. $autolunch_exists = true;
  343. $lp_auto_lunch_icon = '<a href="'.api_get_self().'?'.api_get_cidreq().'&action=auto_launch&status=0&lp_id='.$id.'">
  344. <img src="../img/launch.png" border="0" title="'.get_lang('DisableLPAutoLaunch').'" /></a>';
  345. } else {
  346. $lp_auto_lunch_icon = '<a href="'.api_get_self().'?'.api_get_cidreq().'&action=auto_launch&status=1&lp_id='.$id.'">
  347. <img src="../img/launch_na.png" border="0" title="'.get_lang('EnableLPAutoLaunch').'" /></a>';
  348. }
  349. }
  350. // Export to PDF
  351. $export_icon = ' <a href="'.api_get_self().'?'.api_get_cidreq().'&action=export_to_pdf&lp_id='.$id.'">
  352. '.Display::return_icon('pdf.png', get_lang('ExportToPDFOnlyHTMLAndImages'), '', ICON_SIZE_SMALL).'</a>';
  353. /* Delete */
  354. if ($current_session == $details['lp_session']) {
  355. $dsp_delete = "<a href=\"lp_controller.php?".api_get_cidreq()."&action=delete&lp_id=$id\" ".
  356. "onclick=\"javascript: return confirmation('".addslashes($name)."');\">".
  357. Display::return_icon('delete.png', get_lang('LearnpathDeleteLearnpath'), '', ICON_SIZE_SMALL).'</a>';
  358. } else {
  359. $dsp_delete = Display::return_icon('delete_na.png', get_lang('LearnpathDeleteLearnpath'), '', ICON_SIZE_SMALL);
  360. }
  361. /* COLUMN ORDER */
  362. // Only active while session mode is not active
  363. if ($current_session == 0) {
  364. if ($details['lp_display_order'] == 1 && $max != 1) {
  365. $dsp_order .= '<a href="lp_controller.php?'.api_get_cidreq().'&action=move_lp_down&lp_id='.$id.'">
  366. '.Display::return_icon('down.png', get_lang('MoveDown'), '', ICON_SIZE_SMALL).'</a>';
  367. } elseif ($current == $max - 1 && $max != 1) {
  368. $dsp_order .= '<a href="lp_controller.php?'.api_get_cidreq().'&action=move_lp_up&lp_id='.$id.'">
  369. '.Display::return_icon('up.png', get_lang('MoveUp'), '', ICON_SIZE_SMALL).'</a>';
  370. } elseif ($max == 1) {
  371. $dsp_order = '';
  372. } else {
  373. $dsp_order .= '<a href="lp_controller.php?'.api_get_cidreq().'&action=move_lp_down&lp_id='.$id.'">'.
  374. Display::return_icon('down.png', get_lang('MoveDown'), '', ICON_SIZE_SMALL).'</a>';
  375. $dsp_order .= '<a href="lp_controller.php?'.api_get_cidreq().'&action=move_lp_up&lp_id='.$id.'">'.
  376. Display::return_icon('up.png', get_lang('MoveUp'), '', ICON_SIZE_SMALL).'</a>';
  377. }
  378. }
  379. if ($is_allowed_to_edit) {
  380. $start_time = Display::tag('td', Display::div($start_time, array('class' => 'small')));
  381. $end_time = Display::tag('td', Display::div($end_time, array('class' => 'small')));
  382. } else {
  383. $start_time = $end_time = '';
  384. }
  385. } else {
  386. // Student
  387. $export_icon = ' <a href="'.api_get_self().'?'.api_get_cidreq().'&action=export_to_pdf&lp_id='.$id.'">'.
  388. Display::return_icon('pdf.png', get_lang('ExportToPDF'), '', ICON_SIZE_SMALL).'</a>';
  389. }
  390. global $_configuration;
  391. if (isset($_configuration['hide_scorm_export_link']) && $_configuration['hide_scorm_export_link']) {
  392. $dsp_disk = null;
  393. }
  394. if (isset($_configuration['hide_scorm_copy_link']) && $_configuration['hide_scorm_copy_link']) {
  395. $copy = null;
  396. }
  397. if (isset($_configuration['hide_scorm_pdf_link']) && $_configuration['hide_scorm_pdf_link']) {
  398. $export_icon = null;
  399. }
  400. echo $dsp_line.$start_time.$end_time.$dsp_progress.$dsp_desc.$dsp_export.$dsp_edit.$dsp_build.$dsp_edit_lp.$dsp_visible.$dsp_publish.$dsp_reinit.
  401. $dsp_default_view.$dsp_debug.$dsp_disk.$copy.$lp_auto_lunch_icon.$export_icon.$dsp_delete.$dsp_order.$dsp_edit_close;
  402. echo "</tr>";
  403. //counter for number of elements treated
  404. $current++;
  405. } // end foreach ($flat_list)
  406. echo "</table>";
  407. } else {
  408. if ($is_allowed_to_edit) {
  409. echo '<div id="no-data-view">';
  410. echo '<h2>'.get_lang('LearningPaths').'</h2>';
  411. echo Display::return_icon('scorms.png', '', array(), 64);
  412. echo '<div class="controls">';
  413. echo Display::url(get_lang('LearnpathAddLearnpath'), api_get_self().'?'.api_get_cidreq().'&action=add_lp', array('class' => 'btn'));
  414. echo '</div>';
  415. echo '</div>';
  416. }
  417. }
  418. $course_info = api_get_course_info();
  419. learnpath::generate_learning_path_folder($course_info);
  420. // Deleting the objects
  421. Session::erase('oLP');
  422. Session::erase('lpobject');
  423. DocumentManager::removeGeneratedAudioTempFile();
  424. Display::display_footer();