* * @package chamilo.forum */ require_once __DIR__.'/../inc/global.inc.php'; // The section (tabs). $this_section = SECTION_COURSES; // Notification for unauthorized people. api_protect_course_script(true); $cidreq = api_get_cidreq(); $nameTools = get_lang('ToolForum'); /* Including necessary files */ require_once 'forumconfig.inc.php'; require_once 'forumfunction.inc.php'; // Are we in a lp ? $origin = api_get_origin(); /* MAIN DISPLAY SECTION */ $forumId = (int) $_GET['forum']; $currentForum = get_forum_information($forumId); $currentForumCategory = get_forumcategory_information($currentForum['forum_category']); // the variable $forum_settings is declared in forumconfig.inc.php $forumSettings = $forum_setting; /* Breadcrumbs */ if (isset($_SESSION['gradebook'])) { $gradebook = Security::remove_XSS($_SESSION['gradebook']); } if (!empty($gradebook) && $gradebook == 'view') { $interbreadcrumb[] = array( 'url' => '../gradebook/'.Security::remove_XSS($_SESSION['gradebook_dest']), 'name' => get_lang('ToolGradebook') ); } $threadId = isset($_GET['thread']) ? intval($_GET['thread']) : 0; $courseInfo = isset($_GET['cidReq']) ? api_get_course_info($_GET['cidReq']) : 0; $cId = isset($courseInfo['real_id']) ? intval($courseInfo['real_id']) : 0; $gradebookId = intval(api_is_in_gradebook()); /* Is the user allowed here? */ // The user is not allowed here if: // 1. the forumcategory or forum is invisible (visibility==0) and the user is not a course manager if (!api_is_allowed_to_edit(false, true) && (($currentForumCategory['visibility'] && $currentForumCategory['visibility'] == 0) || $currentForum['visibility'] == 0) ) { api_not_allowed(); } // 2. the forumcategory or forum is locked (locked <>0) and the user is not a course manager if (!api_is_allowed_to_edit(false, true) && (($currentForumCategory['visibility'] && $currentForumCategory['locked'] <> 0) || $currentForum['locked'] <> 0) ) { api_not_allowed(); } // 3. new threads are not allowed and the user is not a course manager if (!api_is_allowed_to_edit(false, true) && $currentForum['allow_new_threads'] <> 1 ) { api_not_allowed(); } // 4. anonymous posts are not allowed and the user is not logged in if (!$_user['user_id'] && $currentForum['allow_anonymous'] <> 1) { api_not_allowed(); } // 5. Check user access if ($currentForum['forum_of_group'] != 0) { $show_forum = GroupManager::user_has_access( api_get_user_id(), $currentForum['forum_of_group'], GroupManager::GROUP_TOOL_FORUM ); if (!$show_forum) { api_not_allowed(); } } // 6. Invited users can't create new threads if (api_is_invitee()) { api_not_allowed(true); } $groupId = api_get_group_id(); if (!empty($groupId)) { $groupProperties = GroupManager :: get_group_properties($groupId); $interbreadcrumb[] = array('url' => api_get_path(WEB_CODE_PATH).'group/group.php?'.$cidreq, 'name' => get_lang('Groups')); $interbreadcrumb[] = array('url' => api_get_path(WEB_CODE_PATH).'group/group_space.php?'.$cidreq, 'name' => get_lang('GroupSpace').' '.$groupProperties['name']); $interbreadcrumb[] = array('url' => api_get_path(WEB_CODE_PATH).'forum/viewforum.php?'.$cidreq.'&forum='.$forumId, 'name' => $currentForum['forum_title']); $interbreadcrumb[] = array('url' => api_get_path(WEB_CODE_PATH).'forum/newthread.php?'.$cidreq.'&forum='.$forumId, 'name' => get_lang('EditThread')); } else { $interbreadcrumb[] = array('url' => api_get_path(WEB_CODE_PATH).'forum/index.php?'.$cidreq, 'name' => $nameTools); $interbreadcrumb[] = array('url' => api_get_path(WEB_CODE_PATH).'forum/viewforumcategory.php?'.$cidreq.'&forumcategory='.$currentForumCategory['cat_id'], 'name' => $currentForumCategory['cat_title']); $interbreadcrumb[] = array('url' => api_get_path(WEB_CODE_PATH).'forum/viewforum.php?'.$cidreq.'&forum='.$forumId, 'name' => $currentForum['forum_title']); $interbreadcrumb[] = array('url' => '#', 'name' => get_lang('EditThread')); } $tableLink = Database::get_main_table(TABLE_MAIN_GRADEBOOK_LINK); /* Header */ $htmlHeadXtra[] = << $(document).on('ready', function() { if ($('#thread_qualify_gradebook').is(':checked') == true) { document.getElementById('options_field').style.display = 'block'; } else { document.getElementById('options_field').style.display = 'none'; } $('#thread_qualify_gradebook').click(function() { if ($('#thread_qualify_gradebook').is(':checked') == true) { document.getElementById('options_field').style.display = 'block'; } else { document.getElementById('options_field').style.display = 'none'; $("[name='numeric_calification']").val(0); $("[name='calification_notebook_title']").val(''); $("[name='weight_calification']").val(0); $("[name='thread_peer_qualify'][value='0']").prop('checked', true); } }); }); JS; // Action links $actions = [ Display::url( Display::return_icon('back.png', get_lang('BackToForum'), '', ICON_SIZE_MEDIUM), 'viewforum.php?forum='.$forumId.'&'.$cidreq ), search_link() ]; $threadData = getThreadInfo($threadId, $cId); $form = new FormValidator( 'thread', 'post', api_get_self().'?'.http_build_query([ 'forum' => $forumId, 'thread' => $threadId, ]).'&'.api_get_cidreq() ); $form->addElement('header', get_lang('EditThread')); $form->setConstants(array('forum' => '5')); $form->addElement('hidden', 'forum_id', $forumId); $form->addElement('hidden', 'thread_id', $threadId); $form->addElement('hidden', 'gradebook', $gradebookId); $form->addElement('text', 'thread_title', get_lang('Title')); $form->addElement('advanced_settings', 'advanced_params', get_lang('AdvancedParameters')); $form->addElement('html', ''); if (!empty($threadData)) { $defaults['thread_qualify_gradebook'] = ($threadData['threadQualifyMax'] > 0 && empty($_POST)) ? 1 : 0; $defaults['thread_title'] = prepare4display($threadData['threadTitle']); $defaults['thread_sticky'] = strval(intval($threadData['threadSticky'])); $defaults['thread_peer_qualify'] = intval($threadData['threadPeerQualify']); $defaults['numeric_calification'] = $threadData['threadQualifyMax']; $defaults['calification_notebook_title'] = $threadData['threadTitleQualify']; $defaults['weight_calification'] = $threadData['threadWeight']; } else { $defaults['thread_qualify_gradebook'] = 0; $defaults['numeric_calification'] = 0; $defaults['calification_notebook_title'] = ''; $defaults['weight_calification'] = 0; $defaults['thread_peer_qualify'] = 0; } $form->setDefaults(isset($defaults) ? $defaults : null); $form->addButtonUpdate(get_lang('ModifyThread'), 'SubmitPost'); if ($form->validate()) { $redirectUrl = api_get_path(WEB_CODE_PATH).'forum/viewforum.php?forum='.$forumId.'&'.api_get_cidreq(); $check = Security::check_token('post'); if ($check) { $values = $form->exportValues(); Security::clear_token(); updateThread($values); header('Location: '.$redirectUrl); exit; } } else { $token = Security::get_token(); $form->addElement('hidden', 'sec_token'); $form->setConstants(array('sec_token' => $token)); } $originIsLearnPath = $origin == 'learnpath'; $view = new Template( '', !$originIsLearnPath, !$originIsLearnPath, $originIsLearnPath, $originIsLearnPath ); $view->assign( 'actions', Display::toolbarAction('toolbar', $actions) ); $view->assign('content', $form->returnForm()); $view->display_one_col_template();