user_portal.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. <?php
  2. /* For licensing terms, see /license.txt */
  3. use ChamiloSession as Session;
  4. /**
  5. * This is the index file displayed when a user is logged in on Chamilo.
  6. *
  7. * It displays:
  8. * - personal course list
  9. * - menu bar
  10. * Search for CONFIGURATION parameters to modify settings
  11. * @package chamilo.main
  12. * @todo Shouldn't the CONFVAL_ constant be moved to the config page? Has anybody any idea what the are used for?
  13. * If these are really configuration settings then we can add those to the dokeos config settings.
  14. * @todo check for duplication of functions with index.php (user_portal.php is orginally a copy of index.php)
  15. * @todo display_digest, shouldn't this be removed and be made into an extension?
  16. */
  17. /* Flag forcing the 'current course' reset, as we're not inside a course anymore */
  18. $cidReset = true;
  19. // For HTML editor repository.
  20. if (isset($_SESSION['this_section'])) {
  21. unset($_SESSION['this_section']);
  22. }
  23. /* Included libraries */
  24. require_once './main/inc/global.inc.php';
  25. $this_section = SECTION_COURSES;
  26. api_block_anonymous_users(); // Only users who are logged in can proceed.
  27. $userId = api_get_user_id();
  28. /* Constants and CONFIGURATION parameters */
  29. $load_dirs = api_get_setting('show_documents_preview');
  30. $displayMyCourseViewBySessionLink = api_get_setting('my_courses_view_by_session') === 'true';
  31. $nameTools = get_lang('MyCourses');
  32. // Load course notification by ajax
  33. $loadNotificationsByAjax = api_get_configuration_value('user_portal_load_notification_by_ajax');
  34. if ($loadNotificationsByAjax) {
  35. $htmlHeadXtra[] = '<script>
  36. $(function() {
  37. $(".course_notification").each(function(index) {
  38. var div = $(this);
  39. var id = $(this).attr("id");
  40. var idList = id.split("_");
  41. var courseId = idList[1];
  42. var sessionId = idList[2];
  43. var status = idList[3];
  44. $.ajax({
  45. type: "GET",
  46. url: "'.api_get_path(WEB_AJAX_PATH).'course_home.ajax.php?a=get_notification&course_id="+courseId+"&session_id="+sessionId+"&status="+status,
  47. success: function(data) {
  48. div.append(data);
  49. }
  50. });
  51. });
  52. });
  53. </script>';
  54. }
  55. /*
  56. Header
  57. Include the HTTP, HTML headers plus the top banner.
  58. */
  59. if ($load_dirs) {
  60. $url = api_get_path(WEB_AJAX_PATH).'document.ajax.php?a=document_preview';
  61. $folder_icon = api_get_path(WEB_IMG_PATH).'icons/22/folder.png';
  62. $close_icon = api_get_path(WEB_IMG_PATH).'loading1.gif';
  63. $htmlHeadXtra[] = '<script>
  64. $(document).ready(function() {
  65. $(".document_preview_container").hide();
  66. $(".document_preview").click(function() {
  67. var my_id = this.id;
  68. var course_id = my_id.split("_")[2];
  69. var session_id = my_id.split("_")[3];
  70. //showing div
  71. $(".document_preview_container").hide();
  72. $("#document_result_" +course_id+"_" + session_id).show();
  73. // Loading
  74. var image = $("img", this);
  75. image.attr("src", "'.$close_icon.'");
  76. $.ajax({
  77. url: "'.$url.'",
  78. data: "course_id="+course_id+"&session_id="+session_id,
  79. success: function(return_value) {
  80. image.attr("src", "'.$folder_icon.'");
  81. $("#document_result_" +course_id+"_" + session_id).html(return_value);
  82. }
  83. });
  84. });
  85. });
  86. </script>';
  87. }
  88. if ($displayMyCourseViewBySessionLink) {
  89. $htmlHeadXtra[] = '
  90. <script>
  91. userId = ' . $userId.'
  92. $(document).ready(function() {
  93. changeMyCoursesView($.cookie("defaultMyCourseView"+userId));
  94. });
  95. /**
  96. * Keep in cookie the last teacher view for the My Courses Tab. default view, or view by session
  97. * @param inView
  98. */
  99. function changeMyCoursesView(inView)
  100. {
  101. $.cookie("defaultMyCourseView"+userId, inView, { expires: 365 });
  102. if (inView == ' . IndexManager::VIEW_BY_SESSION.') {
  103. $("#viewBySession").addClass("btn-primary");
  104. $("#viewByDefault").removeClass("btn-primary");
  105. } else {
  106. $("#viewByDefault").addClass("btn-primary");
  107. $("#viewBySession").removeClass("btn-primary");
  108. }
  109. }
  110. </script>';
  111. }
  112. $controller = new IndexManager(get_lang('MyCourses'));
  113. // Main courses and session list
  114. if (isset($_COOKIE['defaultMyCourseView'.$userId]) &&
  115. $_COOKIE['defaultMyCourseView'.$userId] == IndexManager::VIEW_BY_SESSION && $displayMyCourseViewBySessionLink
  116. ) {
  117. $courseAndSessions = $controller->returnCoursesAndSessionsViewBySession($userId);
  118. IndexManager::setDefaultMyCourseView(IndexManager::VIEW_BY_SESSION, $userId);
  119. } else {
  120. $courseAndSessions = $controller->returnCoursesAndSessions($userId);
  121. IndexManager::setDefaultMyCourseView(IndexManager::VIEW_BY_DEFAULT, $userId);
  122. }
  123. // if teacher, session coach or admin, display the button to change te course view
  124. if ($displayMyCourseViewBySessionLink &&
  125. (api_is_drh() || api_is_course_coach() || api_is_platform_admin() || api_is_session_admin() || api_is_teacher())
  126. ) {
  127. $courseAndSessions['html'] = "<div class='view-by-session-link'>
  128. <div class='btn-group pull-right'>
  129. <a class='btn btn-default' id='viewByDefault' href='user_portal.php' onclick='changeMyCoursesView(\"".IndexManager::VIEW_BY_DEFAULT."\")'>
  130. ".get_lang('MyCoursesDefaultView')."
  131. </a>
  132. <a class='btn btn-default' id='viewBySession' href='user_portal.php' onclick='changeMyCoursesView(\"".IndexManager::VIEW_BY_SESSION."\")'>
  133. ".get_lang('MyCoursesSessionView')."
  134. </a>
  135. </div>
  136. </div><br /><br />
  137. ".$courseAndSessions['html'];
  138. }
  139. // Check if a user is enrolled only in one course for going directly to the course after the login.
  140. if (api_get_setting('go_to_course_after_login') == 'true') {
  141. $count_of_sessions = $courseAndSessions['session_count'];
  142. $count_of_courses_no_sessions = $courseAndSessions['course_count'];
  143. // User is subscribe in 1 session and 0 courses.
  144. if ($count_of_sessions == 1 && $count_of_courses_no_sessions == 0) {
  145. $sessions = SessionManager::get_sessions_by_user($userId);
  146. if (isset($sessions[0])) {
  147. $sessionInfo = $sessions[0];
  148. // Session only has 1 course.
  149. if (isset($sessionInfo['courses']) && count($sessionInfo['courses']) == 1) {
  150. $courseCode = $sessionInfo['courses'][0]['code'];
  151. $courseInfo = api_get_course_info_by_id($sessionInfo['courses'][0]['real_id']);
  152. $courseUrl = $courseInfo['course_public_url'].'?id_session='.$sessionInfo['session_id'];
  153. header('Location:'.$courseUrl);
  154. exit;
  155. }
  156. // Session has many courses.
  157. if (isset($sessionInfo['session_id'])) {
  158. $url = api_get_path(WEB_CODE_PATH).'session/?session_id='.$sessionInfo['session_id'];
  159. header('Location:'.$url);
  160. exit;
  161. }
  162. }
  163. }
  164. // User is subscribed to 1 course.
  165. if (!isset($_SESSION['coursesAlreadyVisited']) &&
  166. $count_of_sessions == 0 && $count_of_courses_no_sessions == 1
  167. ) {
  168. $courses = CourseManager::get_courses_list_by_user_id(
  169. $userId
  170. );
  171. if (!empty($courses) && isset($courses[0]) && isset($courses[0]['code'])) {
  172. $courseInfo = api_get_course_info_by_id($courses[0]['real_id']);
  173. if (!empty($courseInfo)) {
  174. $courseUrl = $courseInfo['course_public_url'];
  175. header('Location:'.$courseUrl);
  176. exit;
  177. }
  178. }
  179. }
  180. }
  181. // Show the chamilo mascot
  182. if (empty($courseAndSessions['html']) && !isset($_GET['history'])) {
  183. $controller->tpl->assign(
  184. 'welcome_to_course_block',
  185. $controller->return_welcome_to_course_block()
  186. );
  187. }
  188. $controller->tpl->assign('content', $courseAndSessions['html']);
  189. // Display the Site Use Cookie Warning Validation
  190. $useCookieValidation = api_get_setting('cookie_warning');
  191. if ($useCookieValidation === 'true') {
  192. if (isset($_POST['acceptCookies'])) {
  193. api_set_site_use_cookie_warning_cookie();
  194. } else {
  195. if (!api_site_use_cookie_warning_cookie_exist()) {
  196. if (Template::isToolBarDisplayedForUser()) {
  197. $controller->tpl->assign('toolBarDisplayed', true);
  198. } else {
  199. $controller->tpl->assign('toolBarDisplayed', false);
  200. }
  201. $controller->tpl->assign('displayCookieUsageWarning', true);
  202. }
  203. }
  204. }
  205. //check for flash and message
  206. $sniff_notification = '';
  207. $some_activex = isset($_SESSION['sniff_check_some_activex']) ? $_SESSION['sniff_check_some_activex'] : null;
  208. $some_plugins = isset($_SESSION['sniff_check_some_plugins']) ? $_SESSION['sniff_check_some_plugins'] : null;
  209. if (!empty($some_activex) || !empty($some_plugins)) {
  210. if (!preg_match("/flash_yes/", $some_activex) && !preg_match("/flash_yes/", $some_plugins)) {
  211. $sniff_notification = Display::return_message(get_lang('NoFlash'), 'warning', true);
  212. //js verification - To annoying of redirecting every time the page
  213. $controller->tpl->assign('sniff_notification', $sniff_notification);
  214. }
  215. }
  216. $diagnosisComplete = true;
  217. if (api_is_student()) {
  218. $extraFieldValue = new ExtraFieldValue('user');
  219. $diagnosisComplete = $extraFieldValue->get_values_by_handler_and_field_variable(
  220. api_get_user_id(),
  221. 'diagnosis_completed'
  222. );
  223. if ($diagnosisComplete === false ||
  224. is_array($diagnosisComplete) && empty($diagnosisComplete['value'])
  225. ) {
  226. $url = api_get_path(WEB_PATH).'search.php';
  227. $link = Display::url($url, $url);
  228. Display::addFlash(
  229. Display::return_message(
  230. sprintf(get_lang('DoDiagnosisNow'), $link),
  231. 'normal',
  232. false
  233. )
  234. );
  235. }
  236. }
  237. $controller->tpl->assign('profile_block', $controller->return_profile_block($diagnosisComplete));
  238. $controller->tpl->assign('user_image_block', $controller->return_user_image_block());
  239. $controller->tpl->assign('course_block', $controller->return_course_block());
  240. $controller->tpl->assign('navigation_course_links', $controller->return_navigation_links());
  241. $controller->tpl->assign('search_block', $controller->return_search_block());
  242. $controller->tpl->assign('classes_block', $controller->return_classes_block());
  243. $controller->tpl->assign('skills_block', $controller->return_skills_links());
  244. $historyClass = '';
  245. if (!empty($_GET['history'])) {
  246. $historyClass = 'courses-history';
  247. }
  248. $controller->tpl->assign('course_history_page', $historyClass);
  249. $controller->tpl->display_two_col_template();
  250. // Deleting the session_id.
  251. Session::erase('session_id');
  252. Session::erase('studentview');
  253. api_remove_in_gradebook();