123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725 |
- <?php
- /* For licensing terms, see /license.txt */
- use \ChamiloSession as Session;
- /**
- * Class IndexManager
- */
- class IndexManager
- {
- // An instance of the template engine
- public $tpl = false;
- public $name = '';
- public $home = '';
- public $default_home = 'home/';
- const VIEW_BY_DEFAULT = 0;
- const VIEW_BY_SESSION = 1;
- /**
- * Construct
- * @param string $title
- */
- public function __construct($title)
- {
- $this->tpl = new Template($title);
- $this->home = api_get_home_path();
- $this->user_id = api_get_user_id();
- $this->load_directories_preview = false;
- if (api_get_setting('show_documents_preview') == 'true') {
- $this->load_directories_preview = true;
- }
- }
- /**
- * @param bool $setLoginForm
- */
- function set_login_form($setLoginForm = true)
- {
- global $loginFailed;
- $login_form = '';
- if (!($this->user_id) || api_is_anonymous($this->user_id)) {
- // Only display if the user isn't logged in.
- $this->tpl->assign('login_language_form', api_display_language_form(true));
- if ($setLoginForm) {
- $this->tpl->assign('login_form', self::display_login_form());
- if ($loginFailed) {
- $this->tpl->assign('login_failed', self::handle_login_failed());
- }
- if (api_get_setting('allow_lostpassword') == 'true' || api_get_setting('allow_registration') == 'true') {
- $login_form .= '<ul class="nav nav-list">';
- if (api_get_setting('allow_registration') != 'false') {
- $login_form .= '<li><a href="main/auth/inscription.php">'.get_lang('Reg').'</a></li>';
- }
- if (api_get_setting('allow_lostpassword') == 'true') {
- $login_form .= '<li><a href="main/auth/lostPassword.php">'.get_lang('LostPassword').'</a></li>';
- }
- $login_form .= '</ul>';
- }
- $this->tpl->assign('login_options', $login_form);
- }
- }
- }
- function return_exercise_block($personal_course_list)
- {
- require_once api_get_path(SYS_CODE_PATH).'exercice/exercise.lib.php';
- $exercise_list = array();
- if (!empty($personal_course_list)) {
- foreach($personal_course_list as $course_item) {
- $course_code = $course_item['c'];
- $session_id = $course_item['id_session'];
- $exercises = get_exercises_to_be_taken($course_code, $session_id);
- foreach($exercises as $exercise_item) {
- $exercise_item['course_code'] = $course_code;
- $exercise_item['session_id'] = $session_id;
- $exercise_item['tms'] = api_strtotime($exercise_item['end_time'], 'UTC');
- $exercise_list[] = $exercise_item;
- }
- }
- if (!empty($exercise_list)) {
- $exercise_list = msort($exercise_list, 'tms');
- $my_exercise = $exercise_list[0];
- $url = Display::url($my_exercise['title'], api_get_path(WEB_CODE_PATH).'exercice/overview.php?exerciseId='.$my_exercise['id'].'&cidReq='.$my_exercise['course_code'].'&id_session='.$my_exercise['session_id']);
- $this->tpl->assign('exercise_url', $url);
- $this->tpl->assign('exercise_end_date', api_convert_and_format_date($my_exercise['end_time'], DATE_FORMAT_SHORT));
- }
- }
- }
- function return_announcements($show_slide = true) {
- // Display System announcements
- $announcement = isset($_GET['announcement']) ? $_GET['announcement'] : null;
- $announcement = intval($announcement);
- if (!api_is_anonymous() && $this->user_id) {
- $visibility = api_is_allowed_to_create_course() ? SystemAnnouncementManager::VISIBLE_TEACHER : SystemAnnouncementManager::VISIBLE_STUDENT;
- if ($show_slide) {
- $announcements = SystemAnnouncementManager :: display_announcements_slider($visibility, $announcement);
- } else {
- $announcements = SystemAnnouncementManager :: display_all_announcements($visibility, $announcement);
- }
- } else {
- if ($show_slide) {
- $announcements = SystemAnnouncementManager :: display_announcements_slider(SystemAnnouncementManager::VISIBLE_GUEST, $announcement);
- } else {
- $announcements = SystemAnnouncementManager :: display_all_announcements(SystemAnnouncementManager::VISIBLE_GUEST, $announcement);
- }
- }
- return $announcements;
- }
- /**
- * Alias for the online_logout() function
- */
- function logout() {
- online_logout($this->user_id, true);
- }
- /**
- * This function checks if there are courses that are open to the world in the platform course categories (=faculties)
- *
- * @param string $category
- * @return boolean
- */
- function category_has_open_courses($category) {
- $setting_show_also_closed_courses = api_get_setting('show_closed_courses') == 'true';
- $main_course_table = Database :: get_main_table(TABLE_MAIN_COURSE);
- $category = Database::escape_string($category);
- $sql_query = "SELECT * FROM $main_course_table WHERE category_code='$category'";
- $sql_result = Database::query($sql_query);
- while ($course = Database::fetch_array($sql_result)) {
- if (!$setting_show_also_closed_courses) {
- if ((api_get_user_id() > 0 && $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM) || ($course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD)) {
- return true; //at least one open course
- }
- } else {
- if (isset($course['visibility'])) {
- return true; // At least one course (it does not matter weither it's open or not because $setting_show_also_closed_courses = true).
- }
- }
- }
- return false;
- }
- /**
- * Displays the right-hand menu for anonymous users:
- * login form, useful links, help section
- * Warning: function defines globals
- * @version 1.0.1
- * @todo does $_plugins need to be global?
- */
- function display_anonymous_right_menu() {
- global $loginFailed, $_user;
- $display_add_course_link = api_is_allowed_to_create_course() && ($_SESSION['studentview'] != 'studentenview');
- $current_user_id = api_get_user_id();
- echo self::set_login_form(false);
- echo self::return_teacher_link();
- echo self::return_notice();
- }
- function return_teacher_link() {
- $html = '';
- if (!empty($this->user_id)) {
- // tabs that are deactivated are added here
- $show_menu = false;
- $show_create_link = false;
- $show_course_link = false;
- if (api_is_platform_admin() || api_is_course_admin() || api_is_allowed_to_create_course()) {
- $show_menu = true;
- $show_course_link = true;
- $show_create_link = true;
- } else {
- if (api_get_setting('allow_students_to_browse_courses') == 'true') {
- $show_menu = true;
- $show_course_link = true;
- }
- }
- if ($show_menu && ($show_create_link || $show_course_link )) {
- $show_menu = true;
- } else {
- $show_menu = false;
- }
- }
- // My Account section
- if ($show_menu) {
- $html .= '<ul class="nav nav-list">';
- if ($show_create_link) {
- $html .= '<li class="add-course"><a href="' . api_get_path(WEB_CODE_PATH) . 'create_course/add_course.php">'.(api_get_setting('course_validation') == 'true' ? get_lang('CreateCourseRequest') : get_lang('CourseCreate')).'</a></li>';
- }
- if ($show_course_link) {
- if (!api_is_drh() && !api_is_session_admin()) {
- $html .= '<li class="list-course"><a href="' . api_get_path(WEB_CODE_PATH) . 'auth/courses.php">'.get_lang('CourseCatalog').'</a></li>';
- } else {
- $html .= '<li><a href="' . api_get_path(WEB_CODE_PATH) . 'dashboard/index.php">'.get_lang('Dashboard').'</a></li>';
- }
- }
- $html .= '</ul>';
- }
- if (!empty($html)) {
- $html = self::show_right_block(get_lang('Courses'), $html, 'teacher_block');
- }
- return $html;
- }
- /**
- * Includes a created page
- * @return string
- */
- public function return_home_page()
- {
- $userId = api_get_user_id();
- global $_configuration;
- // Including the page for the news
- $html = '';
- if (!empty($_GET['include']) && preg_match('/^[a-zA-Z0-9_-]*\.html$/', $_GET['include'])) {
- $open = @(string)file_get_contents(api_get_path(SYS_PATH).$this->home.$_GET['include']);
- $html = api_to_system_encoding($open, api_detect_encoding(strip_tags($open)));
- } else {
- // Hiding home top when user not connected.
- if (isset($_configuration['hide_home_top_when_connected']) &&
- $_configuration['hide_home_top_when_connected'] && !empty($userId)
- ) {
- return $html;
- }
- if (!empty($_SESSION['user_language_choice'])) {
- $user_selected_language = $_SESSION['user_language_choice'];
- } elseif (!empty($_SESSION['_user']['language'])) {
- $user_selected_language = $_SESSION['_user']['language'];
- } else {
- $user_selected_language = api_get_setting('platformLanguage');
- }
- // Try language specific home
- if (file_exists($this->home.'home_top_'.$user_selected_language.'.html')) {
- $home_top_temp = file_get_contents($this->home.'home_top_'.$user_selected_language.'.html');
- }
- // Try default language home
- if (empty($home_top_temp)) {
- if (file_exists($this->home.'home_top.html')) {
- $home_top_temp = file_get_contents($this->home.'home_top.html');
- } else {
- if (file_exists($this->default_home.'home_top.html')) {
- $home_top_temp = file_get_contents($this->default_home . 'home_top.html');
- }
- }
- }
- if (trim($home_top_temp) == '' && api_is_platform_admin()) {
- $home_top_temp = '<div class="welcome-mascot">' . get_lang('PortalHomepageDefaultIntroduction') . '</div>';
- } else {
- $home_top_temp = '<div class="welcome-home-top-temp">' . $home_top_temp . '</div>';
- }
- $open = str_replace('{rel_path}', api_get_path(REL_PATH), $home_top_temp);
- $html = api_to_system_encoding($open, api_detect_encoding(strip_tags($open)));
- }
- return $html;
- }
- function return_notice() {
- $sys_path = api_get_path(SYS_PATH);
- $user_selected_language = api_get_interface_language();
- $html = '';
- // Notice
- $home_notice = @(string)file_get_contents($sys_path.$this->home.'home_notice_'.$user_selected_language.'.html');
- if (empty($home_notice)) {
- $home_notice = @(string)file_get_contents($sys_path.$this->home.'home_notice.html');
- }
- if (!empty($home_notice)) {
- $home_notice = api_to_system_encoding($home_notice, api_detect_encoding(strip_tags($home_notice)));
- $home_notice = Display::div($home_notice, array('class' => 'homepage_notice'));
- $html = self::show_right_block(get_lang('Notice'), $home_notice, 'notice_block');
- }
- return $html;
- }
- function return_help() {
- $user_selected_language = api_get_interface_language();
- $sys_path = api_get_path(SYS_PATH);
- $platformLanguage = api_get_setting('platformLanguage');
- // Help section.
- /* Hide right menu "general" and other parts on anonymous right menu. */
- if (!isset($user_selected_language)) {
- $user_selected_language = $platformLanguage;
- }
- $html = null;
- $home_menu = @(string)file_get_contents($sys_path.$this->home.'home_menu_'.$user_selected_language.'.html');
- if (!empty($home_menu)) {
- $home_menu_content = '<ul class="nav nav-list">';
- $home_menu_content .= api_to_system_encoding($home_menu, api_detect_encoding(strip_tags($home_menu)));
- $home_menu_content .= '</ul>';
- $html .= self::show_right_block(get_lang('MenuGeneral'), $home_menu_content, 'help_block');
- }
- return $html;
- }
- function return_skills_links() {
- $html = '';
- if (api_get_setting('allow_skills_tool') == 'true') {
- $content = '<ul class="nav nav-list">';
- $content .= Display::tag('li', Display::url(get_lang('MySkills'), api_get_path(WEB_CODE_PATH).'social/skills_wheel.php'));
- $allowSkillsManagement = api_get_setting('allow_hr_skills_management') == 'true';
- if (($allowSkillsManagement && api_is_drh()) || api_is_platform_admin()) {
- $content .= Display::tag('li', Display::url(get_lang('ManageSkills'), api_get_path(WEB_CODE_PATH).'admin/skills_wheel.php'));
- }
- $content .= '</ul>';
- $html = self::show_right_block(get_lang("Skills"), $content, 'skill_block');
- }
- return $html;
- }
- /**
- * Reacts on a failed login:
- * Displays an explanation with a link to the registration form.
- *
- * @version 1.0.1
- */
- function handle_login_failed() {
- $message = get_lang('InvalidId');
- if (!isset($_GET['error'])) {
- if (api_is_self_registration_allowed()) {
- $message = get_lang('InvalidForSelfRegistration');
- }
- } else {
- switch ($_GET['error']) {
- case '':
- if (api_is_self_registration_allowed()) {
- $message = get_lang('InvalidForSelfRegistration');
- }
- break;
- case 'account_expired':
- $message = get_lang('AccountExpired');
- break;
- case 'account_inactive':
- $message = get_lang('AccountInactive');
- break;
- case 'user_password_incorrect':
- $message = get_lang('InvalidId');
- break;
- case 'access_url_inactive':
- $message = get_lang('AccountURLInactive');
- break;
- case 'wrong_captcha':
- $message = get_lang('TheTextYouEnteredDoesNotMatchThePicture');
- break;
- case 'blocked_by_captcha':
- $message = get_lang('AccountBlockedByCaptcha');
- break;
- case 'multiple_connection_not_allowed':
- $message = get_lang('MultipleConnectionsAreNotAllow');
- break;
- case 'unrecognize_sso_origin':
- //$message = get_lang('SSOError');
- break;
- case 'user_doesnt_exist':
- $message = get_lang("UserDoesntExist");
- break;
- }
- }
- return Display::return_message($message, 'error');
- }
- /**
- * Display list of courses in a category.
- * (for anonymous users)
- *
- * @version 1.1
- * @author Patrick Cool <patrick.cool@UGent.be>, Ghent University - refactoring and code cleaning
- * @author Julio Montoya <gugli100@gmail.com>, Beeznest template modifs
- */
- function return_courses_in_categories() {
- $result = '';
- $stok = Security::get_token();
- // Initialization.
- $user_identified = (api_get_user_id() > 0 && !api_is_anonymous());
- $web_course_path = api_get_path(WEB_COURSE_PATH);
- $category = Database::escape_string($_GET['category']);
- $setting_show_also_closed_courses = api_get_setting('show_closed_courses') == 'true';
- // Database table definitions.
- $main_course_table = Database :: get_main_table(TABLE_MAIN_COURSE);
- $main_category_table = Database :: get_main_table(TABLE_MAIN_CATEGORY);
- // Get list of courses in category $category.
- $sql_get_course_list = "SELECT * FROM $main_course_table cours
- WHERE category_code = '".Database::escape_string($_GET['category'])."'
- ORDER BY title, UPPER(visual_code)";
- // Showing only the courses of the current access_url_id.
- global $_configuration;
- if ($_configuration['multiple_access_urls']) {
- $url_access_id = api_get_current_access_url_id();
- if ($url_access_id != -1) {
- $tbl_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $sql_get_course_list = "SELECT * FROM $main_course_table as course INNER JOIN $tbl_url_rel_course as url_rel_course
- ON (url_rel_course.course_code=course.code)
- WHERE access_url_id = $url_access_id AND category_code = '".Database::escape_string($_GET['category'])."' ORDER BY title, UPPER(visual_code)";
- }
- }
- // Removed: AND cours.visibility='".COURSE_VISIBILITY_OPEN_WORLD."'
- $sql_result_courses = Database::query($sql_get_course_list);
- while ($course_result = Database::fetch_array($sql_result_courses)) {
- $course_list[] = $course_result;
- }
- // $setting_show_also_closed_courses
- if ($user_identified) {
- if ($setting_show_also_closed_courses) {
- $platform_visible_courses = '';
- } else {
- $platform_visible_courses = " AND (t3.visibility='".COURSE_VISIBILITY_OPEN_WORLD."' OR t3.visibility='".COURSE_VISIBILITY_OPEN_PLATFORM."' )";
- }
- } else {
- if ($setting_show_also_closed_courses) {
- $platform_visible_courses = '';
- } else {
- $platform_visible_courses = " AND (t3.visibility='".COURSE_VISIBILITY_OPEN_WORLD."' )";
- }
- }
- $sqlGetSubCatList = "
- SELECT t1.name,
- t1.code,
- t1.parent_id,
- t1.children_count,COUNT(DISTINCT t3.code) AS nbCourse
- FROM $main_category_table t1
- LEFT JOIN $main_category_table t2 ON t1.code=t2.parent_id
- LEFT JOIN $main_course_table t3 ON (t3.category_code = t1.code $platform_visible_courses)
- WHERE t1.parent_id ". (empty ($category) ? "IS NULL" : "='$category'")."
- GROUP BY t1.name,t1.code,t1.parent_id,t1.children_count ORDER BY t1.tree_pos, t1.name";
- // Showing only the category of courses of the current access_url_id
- if (api_is_multiple_url_enabled()) {
- require_once api_get_path(LIBRARY_PATH).'course_category.lib.php';
- $courseCategoryCondition = null;
- if (isMultipleUrlSupport()) {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $courseCategoryCondition = " INNER JOIN $table a ON (t1.id = a.course_category_id)";
- }
- $url_access_id = api_get_current_access_url_id();
- if ($url_access_id != -1) {
- $tbl_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $sqlGetSubCatList = "
- SELECT t1.name,
- t1.code,
- t1.parent_id,
- t1.children_count,
- COUNT(DISTINCT t3.code) AS nbCourse
- FROM $main_category_table t1
- $courseCategoryCondition
- LEFT JOIN $main_category_table t2 ON t1.code = t2.parent_id
- LEFT JOIN $main_course_table t3 ON (t3.category_code=t1.code $platform_visible_courses)
- INNER JOIN $tbl_url_rel_course as url_rel_course
- ON (url_rel_course.course_code=t3.code)
- WHERE url_rel_course.access_url_id = $url_access_id AND t1.parent_id ".(empty($category) ? "IS NULL" : "='$category'")."
- GROUP BY t1.name,t1.code,t1.parent_id,t1.children_count ORDER BY t1.tree_pos, t1.name";
- }
- }
- $resCats = Database::query($sqlGetSubCatList);
- $thereIsSubCat = false;
- if (Database::num_rows($resCats) > 0) {
- $htmlListCat = Display::page_header(get_lang('CatList'));
- $htmlListCat .= '<ul>';
- $htmlTitre = '';
- while ($catLine = Database::fetch_array($resCats)) {
- $category_has_open_courses = self::category_has_open_courses($catLine['code']);
- if ($category_has_open_courses) {
- // The category contains courses accessible to anonymous visitors.
- $htmlListCat .= '<li>';
- $htmlListCat .= '<a href="'.api_get_self().'?category='.$catLine['code'].'">'.$catLine['name'].'</a>';
- if (api_get_setting('show_number_of_courses') == 'true') {
- $htmlListCat .= ' ('.$catLine['nbCourse'].' '.get_lang('Courses').')';
- }
- $htmlListCat .= "</li>";
- $thereIsSubCat = true;
- } elseif ($catLine['children_count'] > 0) {
- // The category has children, subcategories.
- $htmlListCat .= '<li>';
- $htmlListCat .= '<a href="'.api_get_self().'?category='.$catLine['code'].'">'.$catLine['name'].'</a>';
- $htmlListCat .= "</li>";
- $thereIsSubCat = true;
- } elseif (api_get_setting('show_empty_course_categories') == 'true') {
- /* End changed code to eliminate the (0 courses) after empty categories. */
- $htmlListCat .= '<li>';
- $htmlListCat .= $catLine['name'];
- $htmlListCat .= "</li>";
- $thereIsSubCat = true;
- } // Else don't set thereIsSubCat to true to avoid printing things if not requested.
- // TODO: deprecate this useless feature - this includes removing system variable
- if (empty($htmlTitre)) {
- $htmlTitre = '<p>';
- if (api_get_setting('show_back_link_on_top_of_tree') == 'true') {
- $htmlTitre .= '<a href="'.api_get_self().'"><< '.get_lang('BackToHomePage').'</a>';
- }
- $htmlTitre .= "</p>";
- }
- }
- $htmlListCat .= "</ul>";
- }
- $result .= $htmlTitre;
- if ($thereIsSubCat) {
- $result .= $htmlListCat;
- }
- while ($categoryName = Database::fetch_array($resCats)) {
- $result .= '<h3>' . $categoryName['name'] . "</h3>\n";
- }
- $numrows = Database::num_rows($sql_result_courses);
- $courses_list_string = '';
- $courses_shown = 0;
- if ($numrows > 0) {
- $courses_list_string .= Display::page_header(get_lang('CourseList'));
- $courses_list_string .= "<ul>";
- if (api_get_user_id()) {
- $courses_of_user = self::get_courses_of_user(api_get_user_id());
- }
- foreach ($course_list as $course) {
- // $setting_show_also_closed_courses
- if ($course['visibility'] == COURSE_VISIBILITY_HIDDEN) { continue; }
- if (!$setting_show_also_closed_courses) {
- // If we do not show the closed courses
- // we only show the courses that are open to the world (to everybody)
- // and the courses that are open to the platform (if the current user is a registered user.
- if (($user_identified && $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM) || ($course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD)) {
- $courses_shown++;
- $courses_list_string .= "<li>";
- $courses_list_string .= '<a href="'.$web_course_path.$course['directory'].'/">'.$course['title'].'</a><br />';
- $course_details = array();
- if (api_get_setting('display_coursecode_in_courselist') == 'true') {
- $course_details[] = $course['visual_code'];
- }
- if (api_get_setting('display_teacher_in_courselist') == 'true') {
- $course_details[] = CourseManager::get_teacher_list_from_course_code_to_string($course['code']);
- }
- if (api_get_setting('show_different_course_language') == 'true' && $course['course_language'] != api_get_setting('platformLanguage')) {
- $course_details[] = $course['course_language'];
- }
- $courses_list_string .= implode(' - ', $course_details);
- $courses_list_string .= "</li>";
- }
- } else {
- // We DO show the closed courses.
- // The course is accessible if (link to the course homepage):
- // 1. the course is open to the world (doesn't matter if the user is logged in or not): $course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD);
- // 2. the user is logged in and the course is open to the world or open to the platform: ($user_identified && $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM);
- // 3. the user is logged in and the user is subscribed to the course and the course visibility is not COURSE_VISIBILITY_CLOSED;
- // 4. the user is logged in and the user is course admin of te course (regardless of the course visibility setting);
- // 5. the user is the platform admin api_is_platform_admin().
- //
- $courses_shown++;
- $courses_list_string .= "<li>";
- if ($course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD
- || ($user_identified && $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM)
- || ($user_identified && array_key_exists($course['code'], $courses_of_user)
- && $course['visibility'] != COURSE_VISIBILITY_CLOSED)
- || $courses_of_user[$course['code']]['status'] == '1'
- || api_is_platform_admin()) {
- $courses_list_string .= '<a href="'.$web_course_path.$course['directory'].'/">';
- }
- $courses_list_string .= $course['title'];
- if ($course['visibility'] == COURSE_VISIBILITY_OPEN_WORLD
- || ($user_identified && $course['visibility'] == COURSE_VISIBILITY_OPEN_PLATFORM)
- || ($user_identified && array_key_exists($course['code'], $courses_of_user)
- && $course['visibility'] != COURSE_VISIBILITY_CLOSED)
- || $courses_of_user[$course['code']]['status'] == '1'
- || api_is_platform_admin()) {
- $courses_list_string .= '</a><br />';
- }
- $course_details = array();
- if (api_get_setting('display_coursecode_in_courselist') == 'true') {
- $course_details[] = $course['visual_code'];
- }
- // if (api_get_setting('display_coursecode_in_courselist') == 'true' && api_get_setting('display_teacher_in_courselist') == 'true') {
- // $courses_list_string .= ' - ';
- // }
- if (api_get_setting('display_teacher_in_courselist') == 'true') {
- if (!empty($course['tutor_name'])) {
- $course_details[] = $course['tutor_name'];
- }
- }
- if (api_get_setting('show_different_course_language') == 'true' && $course['course_language'] != api_get_setting('platformLanguage')) {
- $course_details[] = $course['course_language'];
- }
- $courses_list_string .= implode(' - ', $course_details);
- // We display a subscription link if:
- // 1. it is allowed to register for the course and if the course is not already in the courselist of the user and if the user is identiefied
- // 2.
- if ($user_identified && !array_key_exists($course['code'], $courses_of_user)) {
- if ($course['subscribe'] == '1') {
- /*$courses_list_string .= '<form action="main/auth/courses.php?action=subscribe&category='.Security::remove_XSS($_GET['category']).'" method="post">';
- $courses_list_string .= '<input type="hidden" name="sec_token" value="'.$stok.'">';
- $courses_list_string .= '<input type="hidden" name="subscribe" value="'.$course['code'].'" />';
- $courses_list_string .= '<input type="image" name="unsub" src="main/img/enroll.gif" alt="'.get_lang('Subscribe').'" />'.get_lang('Subscribe').'</form>';
- */
- $courses_list_string .= ' <a class="btn btn-primary" href="main/auth/courses.php?action=subscribe_course&sec_token='.$stok.'&subscribe_course='.$course['code'].'&category_code='.Security::remove_XSS($_GET['category']).'">'.get_lang('Subscribe').'</a><br />';
- } else {
- $courses_list_string .= '<br />'.get_lang('SubscribingNotAllowed');
- }
- }
- $courses_list_string .= "</li>";
- } //end else
- } // end foreach
- $courses_list_string .= "</ul>";
- }
- if ($courses_shown > 0) {
- // Only display the list of courses and categories if there was more than
- // 0 courses visible to the world (we're in the anonymous list here).
- $result .= $courses_list_string;
- }
- if ($category != '') {
- $result .= '<p><a href="'.api_get_self().'"> ' . Display :: return_icon('back.png', get_lang('BackToHomePage')) . get_lang('BackToHomePage') . '</a></p>';
- }
- return $result;
- }
- /**
- * retrieves all the courses that the user has already subscribed to
- * @author Patrick Cool <patrick.cool@UGent.be>, Ghent University, Belgium
- * @param int $user_id: the id of the user
- * @return array an array containing all the information of the courses of the given user
- */
- function get_courses_of_user($user_id) {
- $table_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $table_course_user = Database::get_main_table(TABLE_MAIN_COURSE_USER);
- // Secondly we select the courses that are in a category (user_course_cat <> 0) and sort these according to the sort of the category
- $user_id = intval($user_id);
- $sql_select_courses = "SELECT course.code k, course.visual_code vc, course.subscribe subscr, course.unsubscribe unsubscr,
- course.title i, course.tutor_name t, course.db_name db, course.directory dir, course_rel_user.status status,
- course_rel_user.sort sort, course_rel_user.user_course_cat user_course_cat
- FROM $table_course course,
- $table_course_user course_rel_user
- WHERE course.code = course_rel_user.course_code
- AND course_rel_user.user_id = '".$user_id."'
- AND course_rel_user.relation_type<>".COURSE_RELATION_TYPE_RRHH."
- ORDER BY course_rel_user.sort ASC";
- $result = Database::query($sql_select_courses);
- $courses = array();
- while ($row = Database::fetch_array($result)) {
- // We only need the database name of the course.
- $courses[$row['k']] = array('db' => $row['db'], 'code' => $row['k'], 'visual_code' => $row['vc'], 'title' => $row['i'], 'directory' => $row['dir'], 'status' => $row['status'], 'tutor' => $row['t'], 'subscribe' => $row['subscr'], 'unsubscribe' => $row['unsubscr'], 'sort' => $row['sort'], 'user_course_category' => $row['user_course_cat']);
- }
- return $courses;
- }
- /**
- * @todo use the template system
- */
- function show_right_block($title, $content, $id = null, $params = null) {
- if (!empty($id)) {
- $params['id'] = $id;
- }
- $params['class'] = 'well sidebar-nav';
- $html = null;
- if (!empty($title)) {
- $html.= '<h4>'.$title.'</h4>';
- }
- $html.= $content;
- $html = Display::div($html, $params);
- return $html;
- }
- /**
- * Adds a form to let users login
- * @version 1.1
- */
- function display_login_form()
- {
- $form = new FormValidator('formLogin', 'POST', null, null, array('class'=>'form-vertical'));
- $form->addElement('text', 'login', get_lang('UserName'), array('id' => 'login', 'class' => 'span2 user_login_icon autocapitalize_off', 'autofocus' => 'autofocus'));
- $form->addElement('password', 'password', get_lang('Pass'), array('id' => 'password', 'class' => 'span2 user_password_icon'));
- global $_configuration;
- // Captcha
- $allowCaptcha = isset($_configuration['allow_captcha']) ? $_configuration['allow_captcha'] : false;
- if ($allowCaptcha) {
- $useCaptcha = isset($_SESSION['loginFailed']) ? $_SESSION['loginFailed'] : null;
- if ($useCaptcha) {
- $ajax = api_get_path(WEB_AJAX_PATH).'form.ajax.php?a=get_captcha';
- $options = array(
- 'width' => 250,
- 'height' => 90,
- 'callback' => $ajax.'&var='.basename(__FILE__, '.php'),
- 'sessionVar' => basename(__FILE__, '.php'),
- 'imageOptions' => array(
- 'font_size' => 20,
- 'font_path' => api_get_path(LIBRARY_PATH).'pchart/fonts/',
- 'font_file' => 'tahoma.ttf',
- //'output' => 'gif'
- )
- );
- // Minimum options using all defaults (including defaults for Image_Text):
- //$options = array('callback' => 'qfcaptcha_image.php');
- $captcha_question = $form->addElement('CAPTCHA_Image', 'captcha_question', '', $options);
- $form->addElement('static', null, null, get_lang('ClickOnTheImageForANewOne'));
- $form->addElement('text', 'captcha', get_lang('EnterTheLettersYouSee'));
- $form->addRule('captcha', get_lang('EnterTheCharactersYouReadInTheImage'), 'required', null, 'client');
- $form->addRule('captcha', get_lang('TheTextYouEnteredDoesNotMatchThePicture'), 'CAPTCHA', $captcha_question);
- }
- }
- $form->addElement('style_submit_button','submitAuth', get_lang('LoginEnter'), array('class' => 'btn'));
- $html = $form->return_form();
- // The validation is located in the local.inc
- /*if ($form->validate()) {
- // Prevent re-use of the same CAPTCHA phrase
- $captcha_question->destroy();
- }*/
- if (api_get_setting('openid_authentication') == 'true') {
- include_once 'main/auth/openid/login.php';
- $html .= '<div>'.openid_form().'</div>';
- }
- return $html;
- }
- function return_search_block() {
- $html = '';
- if (api_get_setting('search_enabled') == 'true') {
- $html .= '<div class="searchbox">';
- $search_btn = get_lang('Search');
- $search_content = '<br />
- <form action="main/search/" method="post">
- <input type="text" id="query" class="span2" name="query" value="" />
- <button class="save" type="submit" name="submit" value="'.$search_btn.'" />'.$search_btn.' </button>
- </form></div>';
- $html .= self::show_right_block(get_lang('Search'), $search_content, 'search_block');
- }
- return $html;
- }
- function return_classes_block() {
- $html = '';
- if (api_get_setting('show_groups_to_users') == 'true') {
- require_once api_get_path(LIBRARY_PATH).'usergroup.lib.php';
- $usergroup = new Usergroup();
- $usergroup_list = $usergroup->get_usergroup_by_user(api_get_user_id());
- $classes = '';
- if (!empty($usergroup_list)) {
- foreach($usergroup_list as $group_id) {
- $data = $usergroup->get($group_id);
- $data['name'] = Display::url($data['name'], api_get_path(WEB_CODE_PATH).'user/classes.php?id='.$data['id']);
- $classes .= Display::tag('li', $data['name']);
- }
- }
- if (api_is_platform_admin()) {
- $classes .= Display::tag('li', Display::url(get_lang('AddClasses') ,api_get_path(WEB_CODE_PATH).'admin/usergroups.php?action=add'));
- }
- if (!empty($classes)) {
- $classes = Display::tag('ul', $classes, array('class'=>'nav nav-list'));
- $html .= self::show_right_block(get_lang('Classes'), $classes, 'classes_block');
- }
- }
- return $html;
- }
- function return_reservation_block() {
- $html = '';
- $booking_content = null;
- if (api_get_setting('allow_reservation') == 'true' && api_is_allowed_to_create_course()) {
- $booking_content .='<ul class="nav nav-list">';
- $booking_content .='<a href="main/reservation/reservation.php">'.get_lang('ManageReservations').'</a><br />';
- $booking_content .='</ul>';
- $html .= self::show_right_block(get_lang('Booking'), $booking_content, 'reservation_block');
- }
- return $html;
- }
- function return_user_image_block() {
- $img_array = UserManager::get_user_picture_path_by_id(api_get_user_id(), 'web', true, true);
- $img_array = UserManager::get_picture_user(api_get_user_id(), $img_array['file'], 50, USER_IMAGE_SIZE_MEDIUM, ' width="90" height="90" ');
- $profile_content = null;
- if (api_get_setting('allow_social_tool') == 'true') {
- $profile_content .='<a style="text-align:center" href="'.api_get_path(WEB_PATH).'main/social/home.php"><img src="'.$img_array['file'].'" '.$img_array['style'].' ></a>';
- } else {
- $profile_content .='<a style="text-align:center" href="'.api_get_path(WEB_PATH).'main/auth/profile.php"><img title="'.get_lang('EditProfile').'" src="'.$img_array['file'].'" '.$img_array['style'].'></a>';
- }
- $html = self::show_right_block(null, $profile_content, 'user_image_block', array('style' => 'text-align:center;'));
- return $html;
- }
- function return_profile_block()
- {
- global $_configuration;
- $user_id = api_get_user_id();
- if (empty($user_id)) {
- return;
- }
- $profile_content = '<ul class="nav nav-list">';
- // @todo Add a platform setting to add the user image.
- if (api_get_setting('allow_message_tool') == 'true') {
- require_once api_get_path(LIBRARY_PATH).'group_portal_manager.lib.php';
- // New messages.
- $number_of_new_messages = MessageManager::get_new_messages();
- // New contact invitations.
- $number_of_new_messages_of_friend = SocialManager::get_message_number_invitation_by_user_id(api_get_user_id());
- // New group invitations sent by a moderator.
- $group_pending_invitations = GroupPortalManager::get_groups_by_user(api_get_user_id(), GROUP_USER_PERMISSION_PENDING_INVITATION, false);
- $group_pending_invitations = count($group_pending_invitations);
- $total_invitations = $number_of_new_messages_of_friend + $group_pending_invitations;
- $cant_msg = Display::badge($number_of_new_messages);
- $link = '';
- if (api_get_setting('allow_social_tool') == 'true') {
- $link = '?f=social';
- }
- $profile_content .= '<li class="inbox-social"><a href="'.api_get_path(WEB_PATH).'main/messages/inbox.php'.$link.'">'.get_lang('Inbox').$cant_msg.' </a></li>';
- $profile_content .= '<li class="new-message-social"><a href="'.api_get_path(WEB_PATH).'main/messages/new_message.php'.$link.'">'.get_lang('Compose').' </a></li>';
- if (api_get_setting('allow_social_tool') == 'true') {
- $total_invitations = Display::badge($total_invitations);
- $profile_content .= '<li class="invitations-social"><a href="'.api_get_path(WEB_PATH).'main/social/invitations.php">'.get_lang('PendingInvitations').$total_invitations.'</a></li>';
- }
- if (isset($_configuration['allow_my_files_link_in_homepage']) && $_configuration['allow_my_files_link_in_homepage']) {
- $profile_content .= '<li class="myfiles-social"><a href="'.api_get_path(WEB_PATH).'main/social/myfiles.php">'.get_lang('MyFiles').'</a></li>';
- }
- }
- $editProfileUrl = api_get_path(WEB_CODE_PATH) . 'auth/profile.php';
- if (api_get_setting('sso_authentication') === 'true') {
- $subSSOClass = api_get_setting('sso_authentication_subclass');
- $objSSO = null;
- if (!empty($subSSOClass)) {
- require_once api_get_path(SYS_CODE_PATH) . 'auth/sso/sso.' . $subSSOClass . '.class.php';
- $subSSOClass = 'sso' . $subSSOClass;
- $objSSO = new $subSSOClass();
- } else {
- $objSSO = new sso();
- }
- $editProfileUrl = $objSSO->generateProfileEditingURL();
- }
- $profile_content .= '<li class="profile-social"><a href="' . $editProfileUrl . '">'.get_lang('EditProfile').'</a></li>';
- $profile_content .= '</ul>';
- $html = self::show_right_block(get_lang('Profile'), $profile_content, 'profile_block');
- return $html;
- }
- function return_navigation_links() {
- $html = '';
- // Deleting the myprofile link.
- if (api_get_setting('allow_social_tool') == 'true') {
- unset($this->tpl->menu_navigation['myprofile']);
- }
- // Main navigation section.
- // Tabs that are deactivated are added here.
- if (!empty($this->tpl->menu_navigation)) {
- $content = '<ul class="nav nav-list">';
- foreach ($this->tpl->menu_navigation as $section => $navigation_info) {
- $current = $section == $GLOBALS['this_section'] ? ' id="current"' : '';
- $content .= '<li'.$current.'>';
- $content .= '<a href="'.$navigation_info['url'].'" target="_self">'.$navigation_info['title'].'</a>';
- $content .= '</li>';
- }
- $content .= '</ul>';
- $html = self::show_right_block(get_lang('MainNavigation'), $content, 'navigation_link_block');
- }
- return $html;
- }
- function return_course_block() {
- $html = '';
- $show_create_link = false;
- $show_course_link = false;
- if ((api_get_setting('allow_users_to_create_courses') == 'false' && !api_is_platform_admin()) || api_is_student()) {
- $display_add_course_link = false;
- } else {
- $display_add_course_link = true;
- }
- //$display_add_course_link = api_is_allowed_to_create_course() && ($_SESSION['studentview'] != 'studentenview');
- if ($display_add_course_link) {
- $show_create_link = true;
- }
- if (api_is_platform_admin() || api_is_course_admin() || api_is_allowed_to_create_course()) {
- $show_course_link = true;
- } else {
- if (api_get_setting('allow_students_to_browse_courses') == 'true') {
- $show_course_link = true;
- }
- }
- // My account section
- $my_account_content = '<ul class="nav nav-list">';
- if ($show_create_link) {
- $my_account_content .= '<li class="add-course"><a href="main/create_course/add_course.php">';
- if (api_get_setting('course_validation') == 'true' && !api_is_platform_admin()) {
- $my_account_content .= get_lang('CreateCourseRequest');
- } else {
- $my_account_content .= get_lang('CourseCreate');
- }
- $my_account_content .= '</a></li>';
- }
- //Sort courses
- $url = api_get_path(WEB_CODE_PATH).'auth/courses.php?action=sortmycourses';
- $my_account_content .= '<li class="order-course">'.Display::url(get_lang('SortMyCourses'), $url, array('class' => 'sort course')).'</li>';
- // Session history
- if (isset($_GET['history']) && intval($_GET['history']) == 1) {
- $my_account_content .= '<li class="history-course"><a href="user_portal.php">'.get_lang('DisplayTrainingList').'</a></li>';
- } else {
- $my_account_content .= '<li class="history-course"><a href="user_portal.php?history=1" >'.get_lang('HistoryTrainingSessions').'</a></li>';
- }
- // Course catalog
- if ($show_course_link) {
- if (!api_is_drh()) {
- $my_account_content .= '<li class="list-course"><a href="main/auth/courses.php" >'.get_lang('CourseCatalog').'</a></li>';
- } else {
- $my_account_content .= '<li><a href="main/dashboard/index.php">'.get_lang('Dashboard').'</a></li>';
- }
- }
- $my_account_content .= '</ul>';
- if (!empty($my_account_content)) {
- $html = self::show_right_block(get_lang('Courses'), $my_account_content, 'course_block');
- }
- return $html;
- }
- /**
- * Prints the session and course list (user_portal.php)
- * @param int $user_id
- * @return string
- */
- public function return_courses_and_sessions($user_id)
- {
- global $_configuration;
- $load_history = (isset($_GET['history']) && intval($_GET['history']) == 1) ? true : false;
- if ($load_history) {
- // Load sessions in category in *history*
- $session_categories = UserManager::get_sessions_by_category(
- $user_id,
- true
- );
- } else {
- // Load sessions in category
- $session_categories = UserManager::get_sessions_by_category(
- $user_id,
- false
- );
- }
- $html = '';
- // Showing history title
- if ($load_history) {
- $html .= Display::page_subheader(get_lang('HistoryTrainingSession'));
- if (empty($session_categories)) {
- $html .= get_lang('YouDoNotHaveAnySessionInItsHistory');
- }
- }
- $courses_html = '';
- $special_courses = '';
- // If we're not in the history view...
- if (!isset($_GET['history'])) {
- // Display special courses.
- $special_courses = CourseManager::display_special_courses($user_id, $this->load_directories_preview);
- // Display courses.
- $courses_html .= CourseManager::display_courses($user_id, $this->load_directories_preview);
- }
- $sessions_with_category = '';
- $sessions_with_no_category = '';
- if (is_array($session_categories)) {
- foreach ($session_categories as $session_category) {
- $session_category_id = $session_category['session_category']['id'];
- // Sessions and courses that are not in a session category
- if ($session_category_id == 0 &&
- isset($session_category['sessions'])
- ) {
- // Independent sessions
- foreach ($session_category['sessions'] as $session) {
- $session_id = $session['session_id'];
- // Don't show empty sessions.
- if (count($session['courses']) < 1) {
- continue;
- }
- // Courses inside the current session.
- $date_session_start = $session['date_start'];
- $date_session_end = $session['date_end'];
- $days_access_before_beginning = $session['nb_days_access_before_beginning'];
- $days_access_after_end = $session['nb_days_access_after_end'];
- $session_now = time();
- $count_courses_session = 0;
- // Loop course content
- $html_courses_session = '';
- $atLeastOneCourseIsVisible = false;
- foreach ($session['courses'] as $course) {
- $is_coach_course = api_is_coach($session_id, $course['code']);
- $allowed_time = 0;
- $dif_time_after = 0;
- if ($date_session_start != '0000-00-00') {
- if ($is_coach_course) {
- $allowed_time = api_strtotime($date_session_start.' 00:00:00') - ($days_access_before_beginning * 86400);
- } else {
- $allowed_time = api_strtotime($date_session_start.' 00:00:00');
- }
- if (!isset($_GET['history'])) {
- if ($date_session_end != '0000-00-00') {
- $endSessionToTms = api_strtotime($date_session_end.' 23:59:59');
- if ($session_now > $endSessionToTms) {
- $dif_time_after = $session_now - $endSessionToTms;
- $dif_time_after = round($dif_time_after/86400);
- }
- }
- }
- }
- if ($session_now > $allowed_time &&
- $days_access_after_end > $dif_time_after - 1
- ) {
- // Read only and accessible.
- $atLeastOneCourseIsVisible = true;
- if (api_get_setting('hide_courses_in_sessions') == 'false') {
- $c = CourseManager::get_logged_user_course_html(
- $course,
- $session_id,
- 'session_course_item',
- true,
- $this->load_directories_preview
- );
- $html_courses_session .= isset($c[1]) ? $c[1] : null;
- }
- $count_courses_session++;
- }
- }
- // No courses to show.
- if ($atLeastOneCourseIsVisible == false) {
- if (empty($html_courses_session)) {
- continue;
- }
- }
- if ($count_courses_session > 0) {
- $params = array();
- $session_box = Display::get_session_title_box($session_id);
- $params['icon'] = Display::return_icon(
- 'window_list.png',
- $session_box['title'],
- array('id' => 'session_img_' . $session_id),
- ICON_SIZE_BIG
- );
- $extra_info = !empty($session_box['coach']) ? $session_box['coach'] : null;
- $extra_info .= !empty($session_box['coach']) ? ' - '.$session_box['dates'] : $session_box['dates'];
- $extra_info .= isset($session_box['duration']) ? ' '.$session_box['duration'] : null;
- $sessionTitleLink = api_get_configuration_value('courses_list_session_title_link');
- $sessionTitleLink = $sessionTitleLink === false ? 1 : $sessionTitleLink;
- if (api_is_drh() || !$sessionTitleLink) {
- $session_link = $session_box['title'];
- $params['link'] = null;
- } else {
- $session_link = Display::tag(
- 'a',
- $session_box['title'],
- array(
- 'href' => api_get_path(
- WEB_CODE_PATH
- ) . 'session/index.php?session_id=' . $session_id
- )
- );
- $params['link'] = api_get_path(WEB_CODE_PATH).'session/index.php?session_id='.$session_id;
- }
- $params['title'] = $session_link;
- $params['subtitle'] = $extra_info;
- $params['right_actions'] = '';
- if (api_is_platform_admin()) {
- $params['right_actions'] .= '<a href="'.api_get_path(WEB_CODE_PATH).'admin/resume_session.php?id_session='.$session_id.'">';
- $params['right_actions'] .= Display::return_icon('edit.png', get_lang('Edit'), array('align' => 'absmiddle'), ICON_SIZE_SMALL).'</a>';
- }
- if (api_get_setting('hide_courses_in_sessions') == 'false') {
- // $params['extra'] .= $html_courses_session;
- }
- $params['description'] = isset($session_box['description']) ? $session_box['description'] : null;
- $parentInfo = CourseManager::course_item_html($params, true);
- if (isset($_configuration['show_simple_session_info']) &&
- $_configuration['show_simple_session_info']
- ) {
- $params['title'] = $session_box['title'];
- $parentInfo = CourseManager::course_item_html_no_icon($params);
- }
- $sessions_with_no_category .= CourseManager::course_item_parent(
- $parentInfo,
- $html_courses_session
- );
- }
- }
- } else {
- // All sessions included in
- $count_courses_session = 0;
- $html_sessions = '';
- if (isset($session_category['sessions'])) {
- foreach ($session_category['sessions'] as $session) {
- $session_id = $session['session_id'];
- // Don't show empty sessions.
- if (count($session['courses']) < 1) {
- continue;
- }
- $date_session_start = $session['date_start'];
- $date_session_end = $session['date_end'];
- $days_access_before_beginning = $session['nb_days_access_before_beginning'];
- $days_access_after_end = $session['nb_days_access_after_end'];
- $session_now = time();
- $html_courses_session = '';
- $count = 0;
- foreach ($session['courses'] as $course) {
- $is_coach_course = api_is_coach(
- $session_id,
- $course['code']
- );
- $dif_time_after = 0;
- $allowed_time = 0;
- if ($is_coach_course) {
- // 24 hours = 86400
- if ($date_session_start != '0000-00-00') {
- $allowed_time = api_strtotime($date_session_start . ' 00:00:00') - ($days_access_before_beginning * 86400);
- }
- if (!isset($_GET['history'])) {
- if ($date_session_end != '0000-00-00') {
- $endSessionToTms = api_strtotime(
- $date_session_end . ' 23:59:59'
- );
- if ($session_now > $endSessionToTms) {
- $dif_time_after = $session_now - $endSessionToTms;
- $dif_time_after = round(
- $dif_time_after / 86400
- );
- }
- }
- }
- } else {
- $allowed_time = api_strtotime(
- $date_session_start . ' 00:00:00'
- );
- }
- if ($session_now > $allowed_time &&
- $days_access_after_end > $dif_time_after - 1
- ) {
- if (api_get_setting('hide_courses_in_sessions') == 'false') {
- $c = CourseManager:: get_logged_user_course_html(
- $course,
- $session_id,
- 'session_course_item'
- );
- $html_courses_session .= $c[1];
- }
- $count_courses_session++;
- $count++;
- }
- }
- $params = array();
- if ($count > 0) {
- $session_box = Display:: get_session_title_box(
- $session_id
- );
- $params['icon'] = Display::return_icon(
- 'window_list.png',
- $session_box['title'],
- array(
- 'width' => '48px',
- 'align' => 'absmiddle',
- 'id' => 'session_img_' . $session_id
- ),
- ICON_SIZE_BIG
- ) . ' ';
- $sessionTitleLink = api_get_configuration_value('courses_list_session_title_link');
- $sessionTitleLink = $sessionTitleLink === false ? 1 : $sessionTitleLink;
- if (api_is_drh() || !$sessionTitleLink) {
- $session_link = $session_box['title'];
- $params['link'] = null;
- } else {
- $session_link = Display::tag(
- 'a',
- $session_box['title'],
- array(
- 'href' => api_get_path(WEB_CODE_PATH) . 'session/index.php?session_id=' . $session_id
- )
- );
- $params['link'] = api_get_path(WEB_CODE_PATH) . 'session/index.php?session_id=' . $session_id;
- }
- $params['title'] = $session_link;
- $params['subtitle'] = (!empty($session_box['coach']) ? $session_box['coach'] . ' | ' : '') . $session_box['dates'];
- if (api_is_platform_admin()) {
- $params['right_actions'] = '<a href="' . api_get_path(WEB_CODE_PATH) . 'admin/resume_session.php?id_session=' . $session_id . '">' .
- Display::return_icon(
- 'edit.png',
- get_lang('Edit'),
- array('align' => 'absmiddle'),
- ICON_SIZE_SMALL
- ) . '</a>';
- }
- $parentInfo = CourseManager::course_item_html(
- $params,
- true
- );
- if (isset($_configuration['show_simple_session_info']) && $_configuration['show_simple_session_info']) {
- $params['title'] = $session_box['title'];
- $parentInfo = CourseManager::course_item_html_no_icon(
- $params
- );
- }
- $html_sessions .= $parentInfo . $html_courses_session;
- }
- }
- }
- if ($count_courses_session > 0) {
- $params = array();
- $params['icon'] = Display::return_icon('folder_blue.png', $session_category['session_category']['name'], array(), ICON_SIZE_LARGE);
- if (api_is_platform_admin()) {
- $params['right_actions'] = '<a href="'.api_get_path(WEB_CODE_PATH).'admin/session_category_edit.php?&id='.$session_category['session_category']['id'].'">'.Display::return_icon('edit.png', get_lang('Edit'), array(), ICON_SIZE_SMALL).'</a>';
- }
- $params['title'] = $session_category['session_category']['name'];
- if (api_is_platform_admin()) {
- $params['link'] = api_get_path(WEB_CODE_PATH).'admin/session_category_edit.php?&id='.$session_category['session_category']['id'];
- }
- $session_category_start_date = $session_category['session_category']['date_start'];
- $session_category_end_date = $session_category['session_category']['date_end'];
- if (!empty($session_category_start_date) && $session_category_start_date != '0000-00-00' && !empty($session_category_end_date) && $session_category_end_date != '0000-00-00' ) {
- $params['subtitle'] = sprintf(get_lang('FromDateXToDateY'), $session_category['session_category']['date_start'], $session_category['session_category']['date_end']);
- } else {
- if (!empty($session_category_start_date) && $session_category_start_date != '0000-00-00') {
- $params['subtitle'] = get_lang('From').' '.$session_category_start_date;
- }
- if (!empty($session_category_end_date) && $session_category_end_date != '0000-00-00') {
- $params['subtitle'] = get_lang('Until').' '.$session_category_end_date;
- }
- }
- $sessions_with_category .= CourseManager::course_item_parent(
- CourseManager::course_item_html($params, true),
- $html_sessions
- );
- }
- }
- }
- }
- return $sessions_with_category.
- $sessions_with_no_category.
- $courses_html.$special_courses;
- }
- /**
- * Shows a welcome message when the user doesn't have any content in the course list
- */
- public function return_welcome_to_course_block()
- {
- $count_courses = CourseManager::count_courses();
- $tpl = $this->tpl->get_template('layout/welcome_to_course.tpl');
- $course_catalog_url = api_get_path(WEB_CODE_PATH).'auth/courses.php';
- $course_list_url = api_get_path(WEB_PATH).'user_portal.php';
- $this->tpl->assign('course_catalog_url', $course_catalog_url);
- $this->tpl->assign('course_list_url', $course_list_url);
- $this->tpl->assign('course_catalog_link', Display::url(get_lang('here'), $course_catalog_url));
- $this->tpl->assign('course_list_link', Display::url(get_lang('here'), $course_list_url));
- $this->tpl->assign('count_courses', $count_courses);
- return $this->tpl->fetch($tpl);
- }
- /**
- * @return array
- */
- public function return_hot_courses()
- {
- return CourseManager::return_hot_courses();
- }
- /**
- * UserPortal view for session, return the HTLK of the course list
- * @param $user_id
- * @return string
- */
- public function returnCoursesAndSessionsViewBySession($user_id)
- {
- $load_history = (isset($_GET['history']) && intval($_GET['history']) == 1) ? true : false;
- if ($load_history) {
- //Load sessions in category in *history*
- $session_categories = UserManager::get_sessions_by_category($user_id, true);
- } else {
- //Load sessions in category
- $session_categories = UserManager::get_sessions_by_category($user_id, false);
- }
- $html = '';
- //Showing history title
- if ($load_history) {
- $html .= Display::page_subheader(get_lang('HistoryTrainingSession'));
- if (empty($session_categories)) {
- $html .= get_lang('YouDoNotHaveAnySessionInItsHistory');
- }
- }
- $special_courses = '';
- $loadDirs = $this->load_directories_preview;
- // If we're not in the history view...
- $listCoursesInfo = array();
- if (!isset($_GET['history'])) {
- // Display special courses
- $special_courses = CourseManager::display_special_courses($user_id, $loadDirs);
- // Display courses
- // [code=>xxx, real_id=>000]
- $listCourses = CourseManager::get_courses_list_by_user_id($user_id, false);
- foreach ($listCourses as $i => $listCourseCodeId) {
- list($userCategoryId, $userCatTitle) = CourseManager::getUserCourseCategoryForCourse(
- $user_id,
- $listCourseCodeId['real_id']
- );
- $listCourse = CourseManager::get_course_information_by_id($listCourseCodeId['real_id']);
- $listCoursesInfo[] = array(
- 'code' => $listCourseCodeId['code'],
- 'id' => $listCourseCodeId['real_id'],
- 'title' => $listCourse['title'],
- 'userCatId' => $userCategoryId,
- 'userCatTitle' => $userCatTitle);
- }
- usort($listCoursesInfo, 'self::compareByCourse');
- }
- if (is_array($session_categories)) {
- // all courses that are in a session
- $listCoursesInSession = SessionManager::getNamedSessionCourseForCoach($user_id);
- }
- // we got all courses
- // for each user category, sorted alphabetically, display courses
- $listUserCategories = CourseManager::get_user_course_categories($user_id);
- $listCoursesAlreadyDisplayed = array();
- uasort($listUserCategories, "self::compareListUserCategory");
- $listUserCategories[0] = '';
- $html = '<div class="session-view-block">';
- foreach ($listUserCategories as $userCategoryId => $userCatTitle) {
- // add user category
- $userCategoryHtml = '';
- if ($userCategoryId != 0) {
- $userCategoryHtml = '<div class="session-view-well">';
- }
- $userCategoryHtml .= self::getHtmlForUserCategory($userCategoryId, $userCatTitle);
- // look for course in this userCat in session courses : $listCoursesInSession
- $htmlCategory = '';
- if (isset($listCoursesInSession[$userCategoryId])) {
- // list of courses in this user cat
- foreach ($listCoursesInSession[$userCategoryId]['courseInUserCatList'] as $i => $listCourse) {
- // add course
- $listCoursesAlreadyDisplayed[$listCourse['courseId']] = 1;
- if ($userCategoryId == 0) {
- $htmlCategory .= '<div class="session-view-well session-view-row" >';
- } else {
- $htmlCategory .= '<div class="session-view-row" >';
- }
- $htmlCategory .= self::getHtmlForCourse(
- $listCourse['courseId'],
- $listCourse['title'],
- $listCourse['courseCode'],
- $userCategoryId,
- 1,
- $loadDirs
- );
- // list of session category
- $htmlSessionCategory = '<div class="session-view-row" style="display:none;" id="courseblock-'.$listCourse['courseId'].'">';
- foreach ($listCourse['sessionCatList'] as $j => $listCategorySession) {
- // add session category
- $htmlSessionCategory .= self::getHtmlSessionCategory(
- $listCategorySession['catSessionId'],
- $listCategorySession['catSessionName']
- );
- // list of session
- $htmlSession = ''; // start
- foreach ($listCategorySession['sessionList'] as $k => $listSession) {
- // add session
- $htmlSession .= '<div class="session-view-row">';
- $htmlSession .= self::getHtmlForSession(
- $listSession['sessionId'],
- $listSession['sessionName'],
- $listCategorySession['catSessionId'],
- $listCourse['courseCode']
- );
- $htmlSession .= '</div>';
- }
- $htmlSession .= ''; // end session block
- $htmlSessionCategory .= $htmlSession;
- }
- $htmlSessionCategory .= '</div>'; // end session cat block
- $htmlCategory .= $htmlSessionCategory .'</div>' ;
- $htmlCategory .= ''; // end course block
- }
- $userCategoryHtml .= $htmlCategory;
- }
- // look for courses in this userCat in not in session courses : $listCoursesInfo
- // if course not already added
- $htmlCategory = '';
- foreach ($listCoursesInfo as $i => $listCourse) {
- if ($listCourse['userCatId'] == $userCategoryId && !isset($listCoursesAlreadyDisplayed[$listCourse['id']])) {
- if ($userCategoryId != 0) {
- $htmlCategory .= '<div class="session-view-row" >';
- } else {
- $htmlCategory .= '<div class="session-view-well">';
- }
- $htmlCategory .= self::getHtmlForCourse(
- $listCourse['id'],
- $listCourse['title'],
- $listCourse['code'],
- $userCategoryId,
- 0,
- $loadDirs
- );
- $htmlCategory .= '</div>';
- }
- }
- $htmlCategory .= '';
- $userCategoryHtml .= $htmlCategory; // end user cat block
- if ($userCategoryId != 0) {
- $userCategoryHtml .= '</div>';
- }
- $html .= $userCategoryHtml; //
- }
- $html .= '</div>';
- return $html.$special_courses;
- }
- /**
- * Return HTML code for personnal user course category
- * @param $id
- * @param $title
- * @return string
- */
- private static function getHtmlForUserCategory($id, $title)
- {
- if ($id == 0) {
- return '';
- }
- $icon = Display::return_icon(
- 'folder_yellow.png',
- $title,
- array('class' => 'sessionView', 'width' => 24),
- ICON_SIZE_LARGE
- );
- return "<div class='session-view-user-category'>$icon<span>$title</span></div>";
- }
- /**
- * return HTML code for course display in session view
- * @param $id
- * @param $title
- * @param $code
- * @param $userCategoryId
- * @param bool $displayButton
- * @param $loadDirs
- * @return string
- */
- private static function getHtmlForCourse($id, $title, $code, $userCategoryId, $displayButton = false, $loadDirs)
- {
- $class = 'session-view-lvl-6';
- if ($userCategoryId != 0 && !$displayButton) {
- $class = 'session-view-lvl-7';
- }
- $class2 = 'session-view-lvl-6';
- if ($displayButton || $userCategoryId != 0) {
- $class2 = 'session-view-lvl-7';
- }
- $button = '';
- if ($displayButton) {
- $button = '<input id="session-view-button-'.intval($id).'" class="session-view-button" type="button" onclick="hideUnhide(\'courseblock-'.intval($id).'\', \'session-view-button-'.intval($id).'\', \'+\', \'-\')" value="+" />';
- }
- $icon = Display::return_icon(
- 'blackboard.png',
- $title,
- array('class' => 'sessionView', 'width' => 24),
- ICON_SIZE_LARGE
- );
- $courseLink = api_get_path(WEB_COURSE_PATH).$code.'/index.php?id_session=0';
- // get html course params
- // ['right_actions'] ['teachers'] ['notifications']
- $tabParams = CourseManager::getCourseParamsForDisplay($id, $loadDirs);
- $teachers = '';
- // teacher list
- if (!empty($tabParams['teachers'])) {
- $teachers = '<p class="'.$class2.' view-by-session-teachers">'.$tabParams['teachers'].'</p>';
- }
- $rightActions = '';
- // notification
- if (!empty($tabParams['right_actions'])) {
- $rightActions = '<div class="view-by-session-right-actions">'.$tabParams['right_actions'].'</div>';
- }
- return "<div>
- $button
- <span class='$class'>$icon
- <a class='sessionView' href='$courseLink'>$title</a>
- </span>".$tabParams['notifications']."$rightActions
- </div>
- $teachers";
- }
- /**
- * return HTML code for session category
- * @param $id
- * @param $title
- * @return string
- */
- private static function getHtmlSessionCategory($id, $title)
- {
- if ($id == 0) {
- return '';
- }
- $icon = Display::return_icon(
- 'folder_blue.png',
- $title,
- array('class' => 'sessionView', 'width' => 24),
- ICON_SIZE_LARGE
- );
- return "<div class='session-view-session-category'>
- <span class='session-view-lvl-2'>
- $icon
- <span>$title</span>
- </span>
- </div>";
- }
- /**
- * return HTML code for session
- * @param $id
- * @param $title
- * @param $categotySessionId
- * @param $courseCode
- * @return string
- */
- private static function getHtmlForSession($id, $title, $categotySessionId, $courseCode)
- {
- $html = '';
- if ($categotySessionId == 0) {
- $class1 = 'session-view-lvl-2'; // session
- $class2 = 'session-view-lvl-4'; // got to course in session link
- } else {
- $class1 = 'session-view-lvl-3'; // session
- $class2 = 'session-view-lvl-5'; // got to course in session link
- }
- $icon = Display::return_icon(
- 'blackboard_blue.png',
- $title,
- array('class' => 'sessionView', 'width' => 24),
- ICON_SIZE_LARGE
- );
- $courseLink = api_get_path(WEB_COURSE_PATH).$courseCode.'/index.php?id_session='.intval($id);
- $html .= "<span class='$class1 session-view-session'>$icon$title</span>";
- $html .= '<div class="'.$class2.' session-view-session-go-to-course-in-session">
- <a class="" href="'.$courseLink.'">'.get_lang('GoToCourseInsideSession').'</a></div>';
- return '<div>'.$html.'</div>';
- }
- /**
- * @param $listA
- * @param $listB
- * @return int
- */
- private static function compareByCourse($listA, $listB)
- {
- if ($listA['userCatTitle'] == $listB['userCatTitle']) {
- if ($listA['title'] == $listB['title']) {
- return 0;
- } else if($listA['title'] > $listB['title']) {
- return 1;
- } else {
- return -1;
- }
- } else if ($listA['userCatTitle'] > $listB['userCatTitle']) {
- return 1;
- } else {
- return -1;
- }
- }
- /**
- * @param $listA
- * @param $listB
- * @return int
- */
- public static function compareListUserCategory($listA, $listB)
- {
- if ($listA['title'] == $listB['title']) {
- return 0;
- } else if($listA['title'] > $listB['title']) {
- return 1;
- } else {
- return -1;
- }
- }
- /**
- * @param $view
- * @param $userId
- */
- public static function setDefaultMyCourseView($view, $userId)
- {
- setcookie('defaultMyCourseView'.$userId, $view);
- }
- }
|