UI Improvements + lots of bugfixes * @package chamilo.forum */ // Delete attachment file if ((isset($_GET['action']) && $_GET['action'] == 'delete_attach') && isset($_GET['id_attach']) ) { delete_attachment(0, $_GET['id_attach']); } $sessionId = api_get_session_id(); $_user = api_get_user_info(); $userId = api_get_user_id(); $groupId = api_get_group_id(); $sortDirection = isset($_GET['posts_order']) && $_GET['posts_order'] === 'desc' ? 'DESC' : 'ASC'; if (isset($current_thread['thread_id'])) { $rows = getPosts($current_thread['thread_id'], $sortDirection); $increment = 0; $clean_forum_id = intval($_GET['forum']); $clean_thread_id = intval($_GET['thread']); $locked = api_resource_is_locked_by_gradebook( $clean_thread_id, LINK_FORUM_THREAD ); $closedPost = null; if (!empty($rows)) { foreach ($rows as $row) { if ($row['user_id'] == '0') { $name = prepare4display($row['poster_name']); } else { $name = api_get_person_name($row['firstname'], $row['lastname']); } $username = sprintf(get_lang('LoginX'), $row['username']); if (($current_forum_category && $current_forum_category['locked'] == 0) && $current_forum['locked'] == 0 && $current_thread['locked'] == 0 || api_is_allowed_to_edit(false, true) ) { if ($_user['user_id'] || ($current_forum['allow_anonymous'] == 1 && !$_user['user_id'])) { if (!api_is_anonymous() && api_is_allowed_to_session_edit(false, true)) { $buttonReply = Display::tag( 'a', ' ' . get_lang('ReplyToMessage'), array( 'href' => 'reply.php?' . api_get_cidreq() . "&forum=$clean_forum_id&thread=$clean_thread_id&post=" . "{$row['post_id']}&action=replymessage&origin=$origin", 'class' => 'btn btn-primary' ) ); $buttonQuote = Display::tag( 'a', ' ' . get_lang('QuoteMessage'), array( 'href' => 'reply.php?' . api_get_cidreq() . "&forum=$clean_forum_id&thread=$clean_thread_id" . "&post={$row['post_id']}&action=quote&origin=$origin", 'class' => 'btn btn-success' ) ); } } } else { if (($current_forum_category && $current_forum_category['locked'] == 1)) { $closedPost = Display::tag( 'div', ' ' . get_lang('ForumcategoryLocked'), array('class' => 'alert alert-warning post-closed') ); } if ($current_forum['locked'] == 1) { $closedPost = Display::tag( 'div', ' ' . get_lang('ForumLocked'), array('class' => 'alert alert-warning post-closed') ); } if ($current_thread['locked'] == 1) { $closedPost = Display::tag( 'div', ' ' . get_lang('ThreadLocked'), array('class' => 'alert alert-warning post-closed') ); } } $html = ''; $html .= '
'; $html .= '
'; $html .= '
'; $html .= '
'; if ($origin != 'learnpath') { if (api_get_course_setting('allow_user_image_forum')) { $html .= '
' . display_user_image($row['user_id'], $name) . '
'; } $html .= Display::tag( 'h4', display_user_link($row['user_id'], $name), array('class' => 'title-username') ); } else { $html .= Display::tag( 'span', $name, array( 'title' => api_htmlentities($username, ENT_QUOTES) ) ); } $html .= Display::tag( 'p', api_convert_and_format_date($row['post_date']), array('class' => 'post-date') ); // get attach id $attachment_list = get_attachment($row['post_id']); $id_attach = !empty($attachment_list) ? $attachment_list['iid'] : ''; $iconEdit = ''; // The user who posted it can edit his thread only if the course admin allowed // this in the properties of the forum // The course admin him/herself can do this off course always if ( GroupManager::is_tutor_of_group($userId, $groupId) || ($current_forum['allow_edit'] == 1 && $row['user_id'] == $_user['user_id']) || ( api_is_allowed_to_edit(false, true) && !(api_is_course_coach() && $current_forum['session_id'] != $sessionId) ) ) { if (api_is_allowed_to_session_edit(false, true)) { if ($locked == false) { $iconEdit .= "" . Display::return_icon('edit.png', get_lang('Edit'), array(), ICON_SIZE_SMALL) . ""; } } } if ($origin != 'learnpath') { if (GroupManager::is_tutor_of_group($userId, $groupId) || api_is_allowed_to_edit(false, true) && !(api_is_course_coach() && $current_forum['session_id'] != $sessionId) ) { if ($locked == false) { $iconEdit .= "" . Display::return_icon('delete.png', get_lang('Delete'), array(), ICON_SIZE_SMALL) . ""; } } if ( api_is_allowed_to_edit(false, true) && !(api_is_course_coach() && $current_forum['session_id'] != $sessionId) ) { $iconEdit .= return_visible_invisible_icon( 'post', $row['post_id'], $row['visible'], array( 'forum' => $clean_forum_id, 'thread' => $clean_thread_id, 'origin' => $origin, ) ); $iconEdit .= ""; if ($increment > 0) { $iconEdit .= "" . Display::return_icon('move.png', get_lang('MovePost'), array(), ICON_SIZE_SMALL) . ""; } } } $user_status = api_get_status_of_user_in_course( $row['user_id'], api_get_course_int_id() ); $current_qualify_thread = showQualify( '1', $row['poster_id'], $_GET['thread'] ); if ( ( $current_thread['thread_peer_qualify'] == 1 || api_is_allowed_to_edit(null, true) ) && $current_thread['thread_qualify_max'] > 0 && $origin != 'learnpath' ) { $my_forum_id = $clean_forum_id; if (isset($_GET['gradebook'])) { $info_thread = get_thread_information($clean_thread_id); $my_forum_id = $info_thread['forum_id']; } $userCanEdit = $current_thread['thread_peer_qualify'] == 1 && $row['poster_id'] != $userId; if (api_is_allowed_to_edit(null, true)) { $userCanEdit = true; } if ($increment > 0 && $locked == false && $userCanEdit) { $iconEdit .= "" . Display::return_icon('quiz.gif', get_lang('Qualify')) . " "; } } if ($iconEdit != '') { $html .= '
' . $iconEdit . '
'; } $html .= $closedPost; $html .= '
'; $html .= '
'; $titlePost = Display::tag( 'h3', $row['post_title'], array('class' => 'forum_post_title') ); $html .= Display::tag( 'div', $titlePost, array('class' => 'post-header') ); // see comments inside forumfunction.inc.php to lower filtering and allow more visual changes $html .= Display::tag( 'div', $row['post_text'], array('class' => 'post-body') ); $html .= '
'; $html .= '
'; $html .= '
'; $html .= '
'; // prepare the notification icon if ( isset( $whatsnew_post_info[$current_forum['forum_id']][$current_thread['thread_id']][$row['post_id']] ) && !empty( $whatsnew_post_info[$current_forum['forum_id']][$current_thread['thread_id']][$row['post_id']] ) && !empty($whatsnew_post_info[$_GET['forum']][$row['thread_id']]) ) { $post_image = Display::return_icon('forumpostnew.gif'); } else { $post_image = Display::return_icon('forumpost.gif'); } if ($row['post_notification'] == '1' && $row['poster_id'] == $_user['user_id']) { $post_image .= Display::return_icon('forumnotification.gif', get_lang('YouWillBeNotified')); } // The post title // The check if there is an attachment $attachment_list = getAllAttachment($row['post_id']); if (!empty($attachment_list) && is_array($attachment_list)) { foreach ($attachment_list as $attachment) { $realname = $attachment['path']; $user_filename = $attachment['filename']; $html .= Display::return_icon('attachment.gif', get_lang('Attachment')); $html .= ' ' . $user_filename . ' '; if (($current_forum['allow_edit'] == 1 && $row['user_id'] == $_user['user_id']) || (api_is_allowed_to_edit(false, true) && !(api_is_course_coach() && $current_forum['session_id'] != $sessionId)) ) { $html .= '  ' . Display::return_icon('delete.png', get_lang('Delete'), array(), ICON_SIZE_SMALL) . '
'; } $html .= '' . $attachment['comment'] . ''; } } $html .= '
'; $html .= '
'; $html .= $buttonReply . ' ' . $buttonQuote; $html .= '
'; $html .= '
'; // The post has been displayed => it can be removed from the what's new array unset($whatsnew_post_info[$current_forum['forum_id']][$current_thread['thread_id']][$row['post_id']]); unset($whatsnew_post_info[$current_forum['forum_id']][$current_thread['thread_id']]); unset($_SESSION['whatsnew_post_info'][$current_forum['forum_id']][$current_thread['thread_id']][$row['post_id']]); unset($_SESSION['whatsnew_post_info'][$current_forum['forum_id']][$current_thread['thread_id']]); $increment++; $html .= '
'; $html .= '
'; echo $html; } } }