"No news" bug + cleaned up the code a bit
This commit is contained in:
@@ -18,76 +18,22 @@ if (!defined('IN_PORTAL'))
|
|||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
$announcement = request_var('announcement', -1);
|
$template->assign_vars(array(
|
||||||
|
'NEWEST_POST_IMG' => $user->img('icon_topic_newest', 'VIEW_NEWEST_POST'),
|
||||||
|
'READ_POST_IMG' => $user->img('icon_topic_latest', 'VIEW_NEWEST_POST'),
|
||||||
|
'GOTO_PAGE_IMG' => $user->img('icon_post_target', 'GOTO_PAGE'),
|
||||||
|
'S_DISPLAY_ANNOUNCEMENTS' => true,
|
||||||
|
));
|
||||||
|
|
||||||
|
$announcement = request_var('announcement', -1);
|
||||||
$start = request_var('ap', 0);
|
$start = request_var('ap', 0);
|
||||||
$start = ($start < 0) ? 0 : $start;
|
$start = ($start < 0) ? 0 : $start;
|
||||||
|
|
||||||
// Pagnition
|
// Fetch announcements from portal/includes/functions.php with check if "read full" is requested.
|
||||||
if ( $portal_config['portal_announcements_archive'] )
|
$portal_announcement_length = ($announcement < 0) ? $portal_config['portal_announcements_length'] : 0;
|
||||||
{
|
$fetch_news = phpbb_fetch_posts($portal_config['portal_global_announcements_forum'], $portal_config['portal_announcements_permissions'], $portal_config['portal_number_of_announcements'], $portal_announcement_length, $portal_config['portal_announcements_day'], 'announcements', $start);
|
||||||
$permissions = $portal_config['portal_announcements_permissions'];
|
|
||||||
$forum_from = $portal_config['portal_global_announcements_forum'];
|
|
||||||
|
|
||||||
$forum_from = ( strpos($forum_from, ',') !== FALSE ) ? explode(',', $forum_from) : (($forum_from != '') ? array($forum_from) : array());
|
|
||||||
|
|
||||||
$str_where = '';
|
|
||||||
|
|
||||||
if( $permissions == TRUE )
|
|
||||||
{
|
|
||||||
$disallow_access = array_unique(array_keys($auth->acl_getf('!f_read', true)));
|
|
||||||
} else {
|
|
||||||
$disallow_access = array();
|
|
||||||
}
|
|
||||||
|
|
||||||
$global_f = 0;
|
|
||||||
|
|
||||||
if( sizeof($forum_from) )
|
|
||||||
{
|
|
||||||
$disallow_access = array_diff($forum_from, $disallow_access);
|
|
||||||
if( !sizeof($disallow_access) )
|
|
||||||
{
|
|
||||||
return array();
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach( $disallow_access as $acc_id)
|
|
||||||
{
|
|
||||||
$acc_id = (int) $acc_id;
|
|
||||||
$str_where .= "forum_id = $acc_id OR ";
|
|
||||||
if( $global_f < 1 && $acc_id > 0 )
|
|
||||||
{
|
|
||||||
$global_f = $acc_id;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
foreach( $disallow_access as $acc_id )
|
|
||||||
{
|
|
||||||
$acc_id = (int) $acc_id;
|
|
||||||
$str_where .= "forum_id <> $acc_id AND ";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$str_where = ( strlen($str_where) > 0 ) ? 'AND (forum_id = 0 OR (' . trim(substr($str_where, 0, -4)) . '))' : '';
|
|
||||||
|
|
||||||
$sql = 'SELECT COUNT(topic_id) AS num_topics
|
|
||||||
FROM ' . TOPICS_TABLE . '
|
|
||||||
WHERE ((topic_type = ' . POST_GLOBAL . ')
|
|
||||||
OR topic_type = ' . POST_ANNOUNCE . ')
|
|
||||||
AND topic_approved = 1
|
|
||||||
AND topic_moved_id = 0
|
|
||||||
' . $str_where;
|
|
||||||
$result = $db->sql_query($sql);
|
|
||||||
$total_announcements = (int) $db->sql_fetchfield('num_topics');
|
|
||||||
$db->sql_freeresult($result);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
if($announcement < 0)
|
|
||||||
{
|
|
||||||
$fetch_news = phpbb_fetch_posts($portal_config['portal_global_announcements_forum'], $portal_config['portal_announcements_permissions'], $portal_config['portal_number_of_announcements'], $portal_config['portal_announcements_length'], $portal_config['portal_announcements_day'], 'announcements', $start);
|
|
||||||
|
|
||||||
|
// Any announcements present? If not terminate it here.
|
||||||
if (count($fetch_news) == 0)
|
if (count($fetch_news) == 0)
|
||||||
{
|
{
|
||||||
$template->assign_block_vars('announcements_row', array(
|
$template->assign_block_vars('announcements_row', array(
|
||||||
@@ -99,31 +45,150 @@ if($announcement < 0)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$count = count($fetch_news)-1;
|
// Count number of posts for announcements archive, considering if permission check is dis- or enabled.
|
||||||
for ($i = 0; $i < $count; $i++)
|
if ( $portal_config['portal_announcements_archive'] )
|
||||||
{
|
{
|
||||||
if( isset($fetch_news[$i]['striped']) && $fetch_news[$i]['striped'] == true )
|
$permissions = $portal_config['portal_announcements_permissions'];
|
||||||
{
|
$forum_from = $portal_config['portal_global_announcements_forum'];
|
||||||
$open_bracket = '[ ';
|
|
||||||
$close_bracket = ' ]';
|
|
||||||
$read_full = $user->lang['READ_FULL'];
|
|
||||||
|
|
||||||
|
$forum_from = ( strpos($forum_from, ',') !== FALSE ) ? explode(',', $forum_from) : (($forum_from != '') ? array($forum_from) : array());
|
||||||
|
|
||||||
|
$str_where = '';
|
||||||
|
|
||||||
|
if( $permissions == TRUE )
|
||||||
|
{
|
||||||
|
$disallow_access = array_unique(array_keys($auth->acl_getf('!f_read', true)));
|
||||||
|
} else {
|
||||||
|
$disallow_access = array();
|
||||||
|
}
|
||||||
|
|
||||||
|
$global_f = 0;
|
||||||
|
|
||||||
|
if( sizeof($forum_from) )
|
||||||
|
{
|
||||||
|
$disallow_access = array_diff($forum_from, $disallow_access);
|
||||||
|
if( !sizeof($disallow_access) )
|
||||||
|
{
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach( $disallow_access as $acc_id)
|
||||||
|
{
|
||||||
|
$acc_id = (int) $acc_id;
|
||||||
|
$str_where .= "forum_id = $acc_id OR ";
|
||||||
|
if( $global_f < 1 && $acc_id > 0 )
|
||||||
|
{
|
||||||
|
$global_f = $acc_id;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$open_bracket = '';
|
foreach( $disallow_access as $acc_id )
|
||||||
$close_bracket = '';
|
{
|
||||||
$read_full = '';
|
$acc_id = (int) $acc_id;
|
||||||
|
$str_where .= "forum_id <> $acc_id AND ";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// unread?
|
|
||||||
|
$str_where = ( strlen($str_where) > 0 ) ? 'AND (forum_id = 0 OR (' . trim(substr($str_where, 0, -4)) . '))' : '';
|
||||||
|
|
||||||
|
$sql = 'SELECT COUNT(topic_id) AS num_topics
|
||||||
|
FROM ' . TOPICS_TABLE . '
|
||||||
|
WHERE ((topic_type = ' . POST_GLOBAL . ')
|
||||||
|
OR topic_type = ' . POST_ANNOUNCE . ')
|
||||||
|
AND topic_approved = 1
|
||||||
|
AND topic_moved_id = 0
|
||||||
|
' . $str_where;
|
||||||
|
$result = $db->sql_query($sql);
|
||||||
|
$total_announcements = (int) $db->sql_fetchfield('num_topics');
|
||||||
|
$db->sql_freeresult($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if($announcement < 0)
|
||||||
|
// Show the announcements overview
|
||||||
|
{
|
||||||
|
$count = count($fetch_news)-1;
|
||||||
|
for ($i = 0; $i < $count; $i++)
|
||||||
|
{
|
||||||
|
if( isset($fetch_news[$i]['striped']) && $fetch_news[$i]['striped'] == true )
|
||||||
|
{
|
||||||
|
$open_bracket = '[ ';
|
||||||
|
$close_bracket = ' ]';
|
||||||
|
$read_full = $user->lang['READ_FULL'];
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$open_bracket = '';
|
||||||
|
$close_bracket = '';
|
||||||
|
$read_full = '';
|
||||||
|
}
|
||||||
|
// unread?
|
||||||
|
$forum_id = $fetch_news[$i]['forum_id'];
|
||||||
|
$topic_id = $fetch_news[$i]['topic_id'];
|
||||||
|
$topic_tracking_info = get_complete_topic_tracking($forum_id, $topic_id, $global_announce_list = false);
|
||||||
|
$unread_topic = (isset($topic_tracking_info[$topic_id]) && $fetch_news[$i]['topic_last_post_time'] > $topic_tracking_info[$topic_id]) ? true : false;
|
||||||
|
|
||||||
|
$real_forum_id = ( $forum_id == 0 ) ? $fetch_news['global_id']: $forum_id;
|
||||||
|
|
||||||
|
$read_full_url = (isset($_GET['ap'])) ? 'ap='. $start . '&announcement=' . $i . '#a' . $i : 'announcement=' . $i . '#a' . $i;
|
||||||
|
$view_topic_url = append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . (($fetch_news[$i]['forum_id']) ? $fetch_news[$i]['forum_id'] : $forum_id) . '&t=' . $topic_id);
|
||||||
|
if ( $portal_config['portal_announcements_archive'] )
|
||||||
|
{
|
||||||
|
$pagination = generate_portal_pagination(append_sid("{$phpbb_root_path}portal.$phpEx"), $total_announcements, $portal_config['portal_number_of_announcements'], $start, 'announcements');
|
||||||
|
}
|
||||||
|
|
||||||
|
$template->assign_block_vars('announcements_row', array(
|
||||||
|
'ATTACH_ICON_IMG' => ($fetch_news[$i]['attachment']) ? $user->img('icon_topic_attach', $user->lang['TOTAL_ATTACHMENTS']) : '',
|
||||||
|
'FORUM_NAME' => ( $forum_id ) ? $fetch_news[$i]['forum_name'] : '',
|
||||||
|
'TITLE' => $fetch_news[$i]['topic_title'],
|
||||||
|
'POSTER' => $fetch_news[$i]['username'],
|
||||||
|
'POSTER_FULL' => $fetch_news[$i]['username_full'],
|
||||||
|
'U_USER_PROFILE' => (($fetch_news[$i]['user_type'] == USER_NORMAL || $fetch_news[$i]['user_type'] == USER_FOUNDER) && $fetch_news[$i]['user_id'] != ANONYMOUS) ? append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=viewprofile&u=' . $fetch_news[$i]['user_id']) : '',
|
||||||
|
'TIME' => $fetch_news[$i]['topic_time'],
|
||||||
|
'TEXT' => $fetch_news[$i]['post_text'],
|
||||||
|
'REPLIES' => $fetch_news[$i]['topic_replies'],
|
||||||
|
'TOPIC_VIEWS' => $fetch_news[$i]['topic_views'],
|
||||||
|
'A_ID' => $i,
|
||||||
|
'U_VIEWFORUM' => append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $fetch_news[$i]['forum_id']),
|
||||||
|
'U_LAST_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", (($real_forum_id) ? 'f=' . $real_forum_id . '&' : '') . 'p=' . $fetch_news[$i]['topic_last_post_id'] . '#p' . $fetch_news[$i]['topic_last_post_id']),
|
||||||
|
'U_VIEW_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 't=' . $topic_id),
|
||||||
|
'U_POST_COMMENT' => append_sid("{$phpbb_root_path}posting.$phpEx", 'mode=reply&' . (($real_forum_id) ? 'f=' . $real_forum_id . '&' : '') . 't=' . $topic_id),
|
||||||
|
'U_READ_FULL' => append_sid("{$phpbb_root_path}portal.$phpEx", $read_full_url),
|
||||||
|
'L_READ_FULL' => $read_full,
|
||||||
|
'OPEN' => $open_bracket,
|
||||||
|
'CLOSE' => $close_bracket,
|
||||||
|
'S_NOT_LAST' => ($i < count($fetch_news) - 1) ? true : false,
|
||||||
|
'S_POLL' => $fetch_news[$i]['poll'],
|
||||||
|
'S_UNREAD_INFO' => $unread_topic,
|
||||||
|
'PAGINATION' => topic_generate_pagination($fetch_news[$i]['topic_replies'], $view_topic_url),
|
||||||
|
));
|
||||||
|
|
||||||
|
if ($portal_config['portal_number_of_announcements'] <> 0 && $portal_config['portal_announcements_archive'])
|
||||||
|
{
|
||||||
|
$template->assign_vars(array(
|
||||||
|
'AP_PAGINATION' => $pagination,
|
||||||
|
'TOTAL_ANNOUNCEMENTS' => ($total_announcements == 1) ? $user->lang['VIEW_LATEST_ANNOUNCEMENT'] : sprintf($user->lang['VIEW_LATEST_ANNOUNCEMENTS'], $total_announcements),
|
||||||
|
'AP_PAGE_NUMBER' => on_page($total_announcements, $portal_config['portal_number_of_announcements'], $start))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
// Show "read full" page
|
||||||
|
{
|
||||||
|
$i = $announcement;
|
||||||
$forum_id = $fetch_news[$i]['forum_id'];
|
$forum_id = $fetch_news[$i]['forum_id'];
|
||||||
$topic_id = $fetch_news[$i]['topic_id'];
|
$topic_id = $fetch_news[$i]['topic_id'];
|
||||||
$topic_tracking_info = get_complete_topic_tracking($forum_id, $topic_id, $global_announce_list = false);
|
$topic_tracking_info = get_complete_topic_tracking($forum_id, $topic_id, $global_announce_list = false);
|
||||||
$unread_topic = (isset($topic_tracking_info[$topic_id]) && $fetch_news[$i]['topic_last_post_time'] > $topic_tracking_info[$topic_id]) ? true : false;
|
$unread_topic = (isset($topic_tracking_info[$topic_id]) && $fetch_news[$i]['topic_last_post_time'] > $topic_tracking_info[$topic_id]) ? true : false;
|
||||||
|
$open_bracket = '[ ';
|
||||||
|
$close_bracket = ' ]';
|
||||||
|
$read_full = $user->lang['BACK'];
|
||||||
|
|
||||||
$real_forum_id = ( $forum_id == 0 ) ? $fetch_news['global_id']: $forum_id;
|
$read_full_url = (isset($_GET['ap'])) ? append_sid("{$phpbb_root_path}portal.$phpEx", "ap=$start#a$i") : append_sid("{$phpbb_root_path}portal.$phpEx#a$i");
|
||||||
|
|
||||||
$read_full_url = (isset($_GET['ap'])) ? 'ap='. $start . '&announcement=' . $i . '#a' . $i : 'announcement=' . $i . '#a' . $i;
|
|
||||||
$view_topic_url = append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . (($fetch_news[$i]['forum_id']) ? $fetch_news[$i]['forum_id'] : $forum_id) . '&t=' . $topic_id);
|
$view_topic_url = append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . (($fetch_news[$i]['forum_id']) ? $fetch_news[$i]['forum_id'] : $forum_id) . '&t=' . $topic_id);
|
||||||
if ( $portal_config['portal_announcements_archive'] )
|
if ( $portal_config['portal_announcements_archive'] )
|
||||||
{
|
{
|
||||||
@@ -131,29 +196,27 @@ if($announcement < 0)
|
|||||||
}
|
}
|
||||||
|
|
||||||
$template->assign_block_vars('announcements_row', array(
|
$template->assign_block_vars('announcements_row', array(
|
||||||
'ATTACH_ICON_IMG' => ($fetch_news[$i]['attachment']) ? $user->img('icon_topic_attach', $user->lang['TOTAL_ATTACHMENTS']) : '',
|
'ATTACH_ICON_IMG' => ($fetch_news[$i]['attachment']) ? $user->img('icon_topic_attach', $user->lang['TOTAL_ATTACHMENTS']) : '',
|
||||||
'FORUM_NAME' => ( $forum_id ) ? $fetch_news[$i]['forum_name'] : '',
|
'FORUM_NAME' => ( $forum_id ) ? $fetch_news[$i]['forum_name'] : '',
|
||||||
'TITLE' => $fetch_news[$i]['topic_title'],
|
'TITLE' => $fetch_news[$i]['topic_title'],
|
||||||
'POSTER' => $fetch_news[$i]['username'],
|
'POSTER' => $fetch_news[$i]['username'],
|
||||||
'POSTER_FULL' => $fetch_news[$i]['username_full'],
|
'POSTER_FULL' => $fetch_news[$i]['username_full'],
|
||||||
'U_USER_PROFILE' => (($fetch_news[$i]['user_type'] == USER_NORMAL || $fetch_news[$i]['user_type'] == USER_FOUNDER) && $fetch_news[$i]['user_id'] != ANONYMOUS) ? append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=viewprofile&u=' . $fetch_news[$i]['user_id']) : '',
|
'TIME' => $fetch_news[$i]['topic_time'],
|
||||||
'TIME' => $fetch_news[$i]['topic_time'],
|
'TEXT' => $fetch_news[$i]['post_text'],
|
||||||
'TEXT' => $fetch_news[$i]['post_text'],
|
'REPLIES' => $fetch_news[$i]['topic_replies'],
|
||||||
'REPLIES' => $fetch_news[$i]['topic_replies'],
|
'TOPIC_VIEWS' => $fetch_news[$i]['topic_views'],
|
||||||
'TOPIC_VIEWS' => $fetch_news[$i]['topic_views'],
|
'A_ID' => $i,
|
||||||
'A_ID' => $i,
|
'U_VIEWFORUM' => append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $fetch_news[$i]['forum_id']),
|
||||||
'U_VIEWFORUM' => append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $fetch_news[$i]['forum_id']),
|
'U_LAST_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", (($forum_id) ? 'f=' . $forum_id . '&' : '') . 'p=' . $fetch_news[$i]['topic_last_post_id'] . '#p' . $fetch_news[$i]['topic_last_post_id']),
|
||||||
'U_LAST_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", (($real_forum_id) ? 'f=' . $real_forum_id . '&' : '') . 'p=' . $fetch_news[$i]['topic_last_post_id'] . '#p' . $fetch_news[$i]['topic_last_post_id']),
|
'U_VIEW_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 't=' . $topic_id),
|
||||||
'U_VIEW_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 't=' . $topic_id),
|
'U_POST_COMMENT' => append_sid("{$phpbb_root_path}posting.$phpEx", 'mode=reply&' . (($forum_id) ? 'f=' . $forum_id . '&' : '') . 't=' . $topic_id),
|
||||||
'U_POST_COMMENT' => append_sid("{$phpbb_root_path}posting.$phpEx", 'mode=reply&' . (($real_forum_id) ? 'f=' . $real_forum_id . '&' : '') . 't=' . $topic_id),
|
'S_POLL' => $fetch_news[$i]['poll'],
|
||||||
'U_READ_FULL' => append_sid("{$phpbb_root_path}portal.$phpEx", $read_full_url),
|
'S_UNREAD_INFO' => $unread_topic,
|
||||||
'L_READ_FULL' => $read_full,
|
'U_READ_FULL' => $read_full_url,
|
||||||
'OPEN' => $open_bracket,
|
'L_READ_FULL' => $read_full,
|
||||||
'CLOSE' => $close_bracket,
|
'OPEN' => $open_bracket,
|
||||||
'S_NOT_LAST' => ($i < count($fetch_news) - 1) ? true : false,
|
'CLOSE' => $close_bracket,
|
||||||
'S_POLL' => $fetch_news[$i]['poll'],
|
'PAGINATION' => topic_generate_pagination($fetch_news[$i]['topic_replies'], $view_topic_url),
|
||||||
'S_UNREAD_INFO' => $unread_topic,
|
|
||||||
'PAGINATION' => topic_generate_pagination($fetch_news[$i]['topic_replies'], $view_topic_url),
|
|
||||||
));
|
));
|
||||||
|
|
||||||
if ($portal_config['portal_number_of_announcements'] <> 0 && $portal_config['portal_announcements_archive'])
|
if ($portal_config['portal_number_of_announcements'] <> 0 && $portal_config['portal_announcements_archive'])
|
||||||
@@ -166,66 +229,5 @@ if($announcement < 0)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$fetch_news = phpbb_fetch_posts($portal_config['portal_global_announcements_forum'], $portal_config['portal_announcements_permissions'], $portal_config['portal_number_of_announcements'], 0, $portal_config['portal_announcements_day'], 'announcements', $start);
|
|
||||||
|
|
||||||
$i = $announcement;
|
|
||||||
$forum_id = $fetch_news[$i]['forum_id'];
|
|
||||||
$topic_id = $fetch_news[$i]['topic_id'];
|
|
||||||
$topic_tracking_info = get_complete_topic_tracking($forum_id, $topic_id, $global_announce_list = false);
|
|
||||||
$unread_topic = (isset($topic_tracking_info[$topic_id]) && $fetch_news[$i]['topic_last_post_time'] > $topic_tracking_info[$topic_id]) ? true : false;
|
|
||||||
$open_bracket = '[ ';
|
|
||||||
$close_bracket = ' ]';
|
|
||||||
$read_full = $user->lang['BACK'];
|
|
||||||
|
|
||||||
$read_full_url = (isset($_GET['ap'])) ? append_sid("{$phpbb_root_path}portal.$phpEx", "ap=$start#a$i") : append_sid("{$phpbb_root_path}portal.$phpEx#a$i");
|
|
||||||
$view_topic_url = append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . (($fetch_news[$i]['forum_id']) ? $fetch_news[$i]['forum_id'] : $forum_id) . '&t=' . $topic_id);
|
|
||||||
if ( $portal_config['portal_announcements_archive'] )
|
|
||||||
{
|
|
||||||
$pagination = generate_portal_pagination(append_sid("{$phpbb_root_path}portal.$phpEx"), $total_announcements, $portal_config['portal_number_of_announcements'], $start, 'announcements');
|
|
||||||
}
|
|
||||||
|
|
||||||
$template->assign_block_vars('announcements_row', array(
|
|
||||||
'ATTACH_ICON_IMG' => ($fetch_news[$i]['attachment']) ? $user->img('icon_topic_attach', $user->lang['TOTAL_ATTACHMENTS']) : '',
|
|
||||||
'FORUM_NAME' => ( $forum_id ) ? $fetch_news[$i]['forum_name'] : '',
|
|
||||||
'TITLE' => $fetch_news[$i]['topic_title'],
|
|
||||||
'POSTER' => $fetch_news[$i]['username'],
|
|
||||||
'POSTER_FULL' => $fetch_news[$i]['username_full'],
|
|
||||||
'TIME' => $fetch_news[$i]['topic_time'],
|
|
||||||
'TEXT' => $fetch_news[$i]['post_text'],
|
|
||||||
'REPLIES' => $fetch_news[$i]['topic_replies'],
|
|
||||||
'TOPIC_VIEWS' => $fetch_news[$i]['topic_views'],
|
|
||||||
'A_ID' => $i,
|
|
||||||
'U_VIEWFORUM' => append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $fetch_news[$i]['forum_id']),
|
|
||||||
'U_LAST_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", (($forum_id) ? 'f=' . $forum_id . '&' : '') . 'p=' . $fetch_news[$i]['topic_last_post_id'] . '#p' . $fetch_news[$i]['topic_last_post_id']),
|
|
||||||
'U_VIEW_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 't=' . $topic_id),
|
|
||||||
'U_POST_COMMENT' => append_sid("{$phpbb_root_path}posting.$phpEx", 'mode=reply&' . (($forum_id) ? 'f=' . $forum_id . '&' : '') . 't=' . $topic_id),
|
|
||||||
'S_POLL' => $fetch_news[$i]['poll'],
|
|
||||||
'S_UNREAD_INFO' => $unread_topic,
|
|
||||||
'U_READ_FULL' => $read_full_url,
|
|
||||||
'L_READ_FULL' => $read_full,
|
|
||||||
'OPEN' => $open_bracket,
|
|
||||||
'CLOSE' => $close_bracket,
|
|
||||||
'PAGINATION' => topic_generate_pagination($fetch_news[$i]['topic_replies'], $view_topic_url),
|
|
||||||
));
|
|
||||||
|
|
||||||
if ($portal_config['portal_number_of_announcements'] <> 0 && $portal_config['portal_announcements_archive'])
|
|
||||||
{
|
|
||||||
$template->assign_vars(array(
|
|
||||||
'AP_PAGINATION' => $pagination,
|
|
||||||
'TOTAL_ANNOUNCEMENTS' => ($total_announcements == 1) ? $user->lang['VIEW_LATEST_ANNOUNCEMENT'] : sprintf($user->lang['VIEW_LATEST_ANNOUNCEMENTS'], $total_announcements),
|
|
||||||
'AP_PAGE_NUMBER' => on_page($total_announcements, $portal_config['portal_number_of_announcements'], $start))
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$template->assign_vars(array(
|
|
||||||
'NEWEST_POST_IMG' => $user->img('icon_topic_newest', 'VIEW_NEWEST_POST'),
|
|
||||||
'READ_POST_IMG' => $user->img('icon_topic_latest', 'VIEW_NEWEST_POST'),
|
|
||||||
'GOTO_PAGE_IMG' => $user->img('icon_post_target', 'GOTO_PAGE'),
|
|
||||||
'S_DISPLAY_ANNOUNCEMENTS' => true,
|
|
||||||
));
|
|
||||||
|
|
||||||
?>
|
?>
|
||||||
@@ -20,9 +20,7 @@ if (!defined('IN_PORTAL'))
|
|||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
|
||||||
// Fetch Posts for news from portal/includes/functions.php
|
|
||||||
//
|
|
||||||
$template->assign_vars(array(
|
$template->assign_vars(array(
|
||||||
'NEWEST_POST_IMG' => $user->img('icon_topic_newest', 'VIEW_NEWEST_POST'),
|
'NEWEST_POST_IMG' => $user->img('icon_topic_newest', 'VIEW_NEWEST_POST'),
|
||||||
'READ_POST_IMG' => $user->img('icon_topic_latest', 'VIEW_NEWEST_POST'),
|
'READ_POST_IMG' => $user->img('icon_topic_latest', 'VIEW_NEWEST_POST'),
|
||||||
@@ -31,70 +29,15 @@ $template->assign_vars(array(
|
|||||||
));
|
));
|
||||||
|
|
||||||
$news = request_var('news', -1);
|
$news = request_var('news', -1);
|
||||||
|
|
||||||
$user->add_lang('viewforum');
|
$user->add_lang('viewforum');
|
||||||
$start = request_var('np', 0);
|
$start = request_var('np', 0);
|
||||||
$start = ($start < 0) ? 0 : $start;
|
$start = ($start < 0) ? 0 : $start;
|
||||||
|
|
||||||
// Pagnition
|
// Fetch news from portal/includes/functions.php with check if "read full" is requested.
|
||||||
if ( $portal_config['portal_news_archive'] )
|
$portal_news_length = ($news < 0) ? $portal_config['portal_news_length'] : 0;
|
||||||
{
|
$fetch_news = phpbb_fetch_posts($portal_config['portal_news_forum'], $portal_config['portal_news_permissions'], $portal_config['portal_number_of_news'], $portal_news_length, 0, ($portal_config['portal_show_all_news']) ? 'news_all' : 'news', $start);
|
||||||
$permissions = $portal_config['portal_news_permissions'];
|
|
||||||
$forum_from = $portal_config['portal_news_forum'];
|
|
||||||
|
|
||||||
$forum_from = ( strpos($forum_from, ',') !== FALSE ) ? explode(',', $forum_from) : (($forum_from != '') ? array($forum_from) : array());
|
|
||||||
|
|
||||||
$str_where = '';
|
|
||||||
|
|
||||||
if( $permissions == TRUE )
|
|
||||||
{
|
|
||||||
$disallow_access = array_unique(array_keys($auth->acl_getf('!f_read', true)));
|
|
||||||
} else {
|
|
||||||
$disallow_access = array();
|
|
||||||
}
|
|
||||||
|
|
||||||
if( sizeof($forum_from) )
|
|
||||||
{
|
|
||||||
$disallow_access = array_diff($forum_from, $disallow_access);
|
|
||||||
if( !sizeof($disallow_access) )
|
|
||||||
{
|
|
||||||
return array();
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach( $disallow_access as $acc_id)
|
|
||||||
{
|
|
||||||
$acc_id = (int) $acc_id;
|
|
||||||
$str_where .= "forum_id = $acc_id OR ";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
foreach( $disallow_access as $acc_id )
|
|
||||||
{
|
|
||||||
$acc_id = (int) $acc_id;
|
|
||||||
$str_where .= "forum_id <> $acc_id AND ";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$str_where = ( strlen($str_where) > 0 ) ? 'AND (' . trim(substr($str_where, 0, -4)) . ')' : '';
|
|
||||||
|
|
||||||
$topic_type = ($portal_config['portal_show_all_news']) ? '( topic_type <> ' . POST_ANNOUNCE . ' ) AND ( topic_type <> ' . POST_GLOBAL . ')' : 'topic_type = ' . POST_NORMAL;
|
|
||||||
|
|
||||||
$sql = 'SELECT COUNT(topic_id) AS num_topics
|
|
||||||
FROM ' . TOPICS_TABLE . '
|
|
||||||
WHERE ' . $topic_type . '
|
|
||||||
AND topic_approved = 1
|
|
||||||
AND topic_moved_id = 0
|
|
||||||
' . $str_where;
|
|
||||||
$result = $db->sql_query($sql);
|
|
||||||
$total_news = (int) $db->sql_fetchfield('num_topics');
|
|
||||||
$db->sql_freeresult($result);
|
|
||||||
}
|
|
||||||
|
|
||||||
if($news < 0)
|
|
||||||
{
|
|
||||||
$fetch_news = phpbb_fetch_posts($portal_config['portal_news_forum'], $portal_config['portal_news_permissions'], $portal_config['portal_number_of_news'], $portal_config['portal_news_length'], 0, ($portal_config['portal_show_all_news']) ? 'news_all' : 'news', $start);
|
|
||||||
|
|
||||||
|
// Any news present? If not terminate it here.
|
||||||
if (count($fetch_news) == 0)
|
if (count($fetch_news) == 0)
|
||||||
{
|
{
|
||||||
$template->assign_block_vars('news_row', array(
|
$template->assign_block_vars('news_row', array(
|
||||||
@@ -104,28 +47,142 @@ if($news < 0)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$count = count($fetch_news)-1;
|
// Count number of posts for news archive, considering if permission check is dis- or enabled.
|
||||||
for ($i = 0; $i < $count; $i++)
|
if ( $portal_config['portal_news_archive'] )
|
||||||
{
|
{
|
||||||
if( isset($fetch_news[$i]['striped']) && $fetch_news[$i]['striped'] == true )
|
$permissions = $portal_config['portal_news_permissions'];
|
||||||
|
$forum_from = $portal_config['portal_news_forum'];
|
||||||
|
|
||||||
|
$forum_from = ( strpos($forum_from, ',') !== FALSE ) ? explode(',', $forum_from) : (($forum_from != '') ? array($forum_from) : array());
|
||||||
|
|
||||||
|
$str_where = '';
|
||||||
|
|
||||||
|
if( $permissions == TRUE )
|
||||||
{
|
{
|
||||||
$open_bracket = '[ ';
|
$disallow_access = array_unique(array_keys($auth->acl_getf('!f_read', true)));
|
||||||
$close_bracket = ' ]';
|
} else {
|
||||||
$read_full = $user->lang['READ_FULL'];
|
$disallow_access = array();
|
||||||
|
}
|
||||||
|
|
||||||
|
if( sizeof($forum_from) )
|
||||||
|
{
|
||||||
|
$disallow_access = array_diff($forum_from, $disallow_access);
|
||||||
|
if( !sizeof($disallow_access) )
|
||||||
|
{
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach( $disallow_access as $acc_id)
|
||||||
|
{
|
||||||
|
$acc_id = (int) $acc_id;
|
||||||
|
$str_where .= "forum_id = $acc_id OR ";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$open_bracket = '';
|
foreach( $disallow_access as $acc_id )
|
||||||
$close_bracket = '';
|
{
|
||||||
$read_full = '';
|
$acc_id = (int) $acc_id;
|
||||||
|
$str_where .= "forum_id <> $acc_id AND ";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// unread?
|
|
||||||
|
$str_where = ( strlen($str_where) > 0 ) ? 'AND (' . trim(substr($str_where, 0, -4)) . ')' : '';
|
||||||
|
|
||||||
|
$topic_type = ($portal_config['portal_show_all_news']) ? '( topic_type <> ' . POST_ANNOUNCE . ' ) AND ( topic_type <> ' . POST_GLOBAL . ')' : 'topic_type = ' . POST_NORMAL;
|
||||||
|
|
||||||
|
$sql = 'SELECT COUNT(topic_id) AS num_topics
|
||||||
|
FROM ' . TOPICS_TABLE . '
|
||||||
|
WHERE ' . $topic_type . '
|
||||||
|
AND topic_approved = 1
|
||||||
|
AND topic_moved_id = 0
|
||||||
|
' . $str_where;
|
||||||
|
$result = $db->sql_query($sql);
|
||||||
|
$total_news = (int) $db->sql_fetchfield('num_topics');
|
||||||
|
$db->sql_freeresult($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
if($news < 0)
|
||||||
|
// Show the news overview
|
||||||
|
{
|
||||||
|
$count = count($fetch_news)-1;
|
||||||
|
for ($i = 0; $i < $count; $i++)
|
||||||
|
{
|
||||||
|
if( isset($fetch_news[$i]['striped']) && $fetch_news[$i]['striped'] == true )
|
||||||
|
{
|
||||||
|
$open_bracket = '[ ';
|
||||||
|
$close_bracket = ' ]';
|
||||||
|
$read_full = $user->lang['READ_FULL'];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$open_bracket = '';
|
||||||
|
$close_bracket = '';
|
||||||
|
$read_full = '';
|
||||||
|
}
|
||||||
|
// unread?
|
||||||
|
$forum_id = $fetch_news[$i]['forum_id'];
|
||||||
|
$topic_id = $fetch_news[$i]['topic_id'];
|
||||||
|
$topic_tracking_info = get_complete_topic_tracking($forum_id, $topic_id, $global_announce_list = false);
|
||||||
|
$unread_topic = (isset($topic_tracking_info[$topic_id]) && $fetch_news[$i]['topic_last_post_time'] > $topic_tracking_info[$topic_id]) ? true : false;
|
||||||
|
|
||||||
|
$read_full_url = (isset($_GET['np'])) ? 'np='. $start . '&news=' . $i . '#n' . $i : 'news=' . $i . '#n' . $i;
|
||||||
|
$view_topic_url = append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . (($fetch_news[$i]['forum_id']) ? $fetch_news[$i]['forum_id'] : $forum_id) . '&t=' . $topic_id);
|
||||||
|
if ( $portal_config['portal_news_archive'] )
|
||||||
|
{
|
||||||
|
$pagination = generate_portal_pagination(append_sid("{$phpbb_root_path}portal.$phpEx"), $total_news, $portal_config['portal_number_of_news'], $start, ($portal_config['portal_show_all_news']) ? 'news_all' : 'news');
|
||||||
|
}
|
||||||
|
|
||||||
|
$template->assign_block_vars('news_row', array(
|
||||||
|
'ATTACH_ICON_IMG' => ($fetch_news[$i]['attachment']) ? $user->img('icon_topic_attach', $user->lang['TOTAL_ATTACHMENTS']) : '',
|
||||||
|
'FORUM_NAME' => ( $forum_id ) ? $fetch_news[$i]['forum_name'] : '',
|
||||||
|
'TITLE' => $fetch_news[$i]['topic_title'],
|
||||||
|
'POSTER' => $fetch_news[$i]['username'],
|
||||||
|
'POSTER_FULL' => $fetch_news[$i]['username_full'],
|
||||||
|
'U_USER_PROFILE' => (($fetch_news[$i]['user_type'] == USER_NORMAL || $fetch_news[$i]['user_type'] == USER_FOUNDER) && $fetch_news[$i]['user_id'] != ANONYMOUS) ? append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=viewprofile&u=' . $fetch_news[$i]['user_id']) : '',
|
||||||
|
'TIME' => $fetch_news[$i]['topic_time'],
|
||||||
|
'TEXT' => $fetch_news[$i]['post_text'],
|
||||||
|
'REPLIES' => $fetch_news[$i]['topic_replies'],
|
||||||
|
'TOPIC_VIEWS' => $fetch_news[$i]['topic_views'],
|
||||||
|
'N_ID' => $i,
|
||||||
|
'U_VIEWFORUM' => append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $fetch_news[$i]['forum_id']),
|
||||||
|
'U_LAST_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $fetch_news[$i]['forum_id'] . '&p=' . $fetch_news[$i]['topic_last_post_id'] . '#p' . $fetch_news[$i]['topic_last_post_id']),
|
||||||
|
'U_VIEW_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $fetch_news[$i]['forum_id'] . '&t=' . $fetch_news[$i]['topic_id']),
|
||||||
|
'U_POST_COMMENT' => append_sid("{$phpbb_root_path}posting.$phpEx", 'mode=reply&f=' . $fetch_news[$i]['forum_id'] . '&t=' . $fetch_news[$i]['topic_id']),
|
||||||
|
'U_READ_FULL' => append_sid("{$phpbb_root_path}portal.$phpEx", $read_full_url),
|
||||||
|
'L_READ_FULL' => $read_full,
|
||||||
|
'OPEN' => $open_bracket,
|
||||||
|
'CLOSE' => $close_bracket,
|
||||||
|
'S_NOT_LAST' => ($i < count($fetch_news) - 1) ? true : false,
|
||||||
|
'S_POLL' => $fetch_news[$i]['poll'],
|
||||||
|
'S_UNREAD_INFO' => $unread_topic,
|
||||||
|
'PAGINATION' => topic_generate_pagination($fetch_news[$i]['topic_replies'], $view_topic_url),
|
||||||
|
));
|
||||||
|
|
||||||
|
if ($portal_config['portal_number_of_news'] <> 0 && $portal_config['portal_news_archive'])
|
||||||
|
{
|
||||||
|
$template->assign_vars(array(
|
||||||
|
'POSTED_BY_TEXT' => ( $portal_config['portal_news_show_last'] ) ? $user->lang['LAST_POST'] : $user->lang['POSTED'],
|
||||||
|
'NP_PAGINATION' => $pagination,
|
||||||
|
'TOTAL_NEWS' => ($total_news == 1) ? $user->lang['VIEW_FORUM_TOPIC'] : sprintf($user->lang['VIEW_FORUM_TOPICS'], $total_news),
|
||||||
|
'NP_PAGE_NUMBER' => on_page($total_news, $portal_config['portal_number_of_news'], $start))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
// Show "read full" page
|
||||||
|
{
|
||||||
|
$i = $news;
|
||||||
$forum_id = $fetch_news[$i]['forum_id'];
|
$forum_id = $fetch_news[$i]['forum_id'];
|
||||||
$topic_id = $fetch_news[$i]['topic_id'];
|
$topic_id = $fetch_news[$i]['topic_id'];
|
||||||
$topic_tracking_info = get_complete_topic_tracking($forum_id, $topic_id, $global_announce_list = false);
|
$topic_tracking_info = get_complete_topic_tracking($forum_id, $topic_id, $global_announce_list = false);
|
||||||
$unread_topic = (isset($topic_tracking_info[$topic_id]) && $fetch_news[$i]['topic_last_post_time'] > $topic_tracking_info[$topic_id]) ? true : false;
|
$unread_topic = (isset($topic_tracking_info[$topic_id]) && $fetch_news[$i]['topic_last_post_time'] > $topic_tracking_info[$topic_id]) ? true : false;
|
||||||
|
$open_bracket = '[ ';
|
||||||
|
$close_bracket = ' ]';
|
||||||
|
$read_full = $user->lang['BACK'];
|
||||||
|
|
||||||
$read_full_url = (isset($_GET['np'])) ? 'np='. $start . '&news=' . $i . '#n' . $i : 'news=' . $i . '#n' . $i;
|
$read_full_url = (isset($_GET['np'])) ? append_sid("{$phpbb_root_path}portal.$phpEx", "np=$start#n$i") : append_sid("{$phpbb_root_path}portal.$phpEx#n$i");
|
||||||
$view_topic_url = append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . (($fetch_news[$i]['forum_id']) ? $fetch_news[$i]['forum_id'] : $forum_id) . '&t=' . $topic_id);
|
$view_topic_url = append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . (($fetch_news[$i]['forum_id']) ? $fetch_news[$i]['forum_id'] : $forum_id) . '&t=' . $topic_id);
|
||||||
if ( $portal_config['portal_news_archive'] )
|
if ( $portal_config['portal_news_archive'] )
|
||||||
{
|
{
|
||||||
@@ -138,7 +195,6 @@ if($news < 0)
|
|||||||
'TITLE' => $fetch_news[$i]['topic_title'],
|
'TITLE' => $fetch_news[$i]['topic_title'],
|
||||||
'POSTER' => $fetch_news[$i]['username'],
|
'POSTER' => $fetch_news[$i]['username'],
|
||||||
'POSTER_FULL' => $fetch_news[$i]['username_full'],
|
'POSTER_FULL' => $fetch_news[$i]['username_full'],
|
||||||
'U_USER_PROFILE' => (($fetch_news[$i]['user_type'] == USER_NORMAL || $fetch_news[$i]['user_type'] == USER_FOUNDER) && $fetch_news[$i]['user_id'] != ANONYMOUS) ? append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=viewprofile&u=' . $fetch_news[$i]['user_id']) : '',
|
|
||||||
'TIME' => $fetch_news[$i]['topic_time'],
|
'TIME' => $fetch_news[$i]['topic_time'],
|
||||||
'TEXT' => $fetch_news[$i]['post_text'],
|
'TEXT' => $fetch_news[$i]['post_text'],
|
||||||
'REPLIES' => $fetch_news[$i]['topic_replies'],
|
'REPLIES' => $fetch_news[$i]['topic_replies'],
|
||||||
@@ -148,20 +204,18 @@ if($news < 0)
|
|||||||
'U_LAST_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $fetch_news[$i]['forum_id'] . '&p=' . $fetch_news[$i]['topic_last_post_id'] . '#p' . $fetch_news[$i]['topic_last_post_id']),
|
'U_LAST_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $fetch_news[$i]['forum_id'] . '&p=' . $fetch_news[$i]['topic_last_post_id'] . '#p' . $fetch_news[$i]['topic_last_post_id']),
|
||||||
'U_VIEW_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $fetch_news[$i]['forum_id'] . '&t=' . $fetch_news[$i]['topic_id']),
|
'U_VIEW_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $fetch_news[$i]['forum_id'] . '&t=' . $fetch_news[$i]['topic_id']),
|
||||||
'U_POST_COMMENT' => append_sid("{$phpbb_root_path}posting.$phpEx", 'mode=reply&f=' . $fetch_news[$i]['forum_id'] . '&t=' . $fetch_news[$i]['topic_id']),
|
'U_POST_COMMENT' => append_sid("{$phpbb_root_path}posting.$phpEx", 'mode=reply&f=' . $fetch_news[$i]['forum_id'] . '&t=' . $fetch_news[$i]['topic_id']),
|
||||||
'U_READ_FULL' => append_sid("{$phpbb_root_path}portal.$phpEx", $read_full_url),
|
|
||||||
'L_READ_FULL' => $read_full,
|
|
||||||
'OPEN' => $open_bracket,
|
|
||||||
'CLOSE' => $close_bracket,
|
|
||||||
'S_NOT_LAST' => ($i < count($fetch_news) - 1) ? true : false,
|
|
||||||
'S_POLL' => $fetch_news[$i]['poll'],
|
'S_POLL' => $fetch_news[$i]['poll'],
|
||||||
'S_UNREAD_INFO' => $unread_topic,
|
'S_UNREAD_INFO' => $unread_topic,
|
||||||
|
'U_READ_FULL' => $read_full_url,
|
||||||
|
'L_READ_FULL' => $read_full,
|
||||||
|
'OPEN' => $open_bracket,
|
||||||
|
'CLOSE' => $close_bracket,
|
||||||
'PAGINATION' => topic_generate_pagination($fetch_news[$i]['topic_replies'], $view_topic_url),
|
'PAGINATION' => topic_generate_pagination($fetch_news[$i]['topic_replies'], $view_topic_url),
|
||||||
));
|
));
|
||||||
|
|
||||||
if ($portal_config['portal_number_of_news'] <> 0 && $portal_config['portal_news_archive'])
|
if ($portal_config['portal_number_of_news'] <> 0 && $portal_config['portal_news_archive'])
|
||||||
{
|
{
|
||||||
$template->assign_vars(array(
|
$template->assign_vars(array(
|
||||||
'POSTED_BY_TEXT' => ( $portal_config['portal_news_show_last'] ) ? $user->lang['LAST_POST'] : $user->lang['POSTED'],
|
|
||||||
'NP_PAGINATION' => $pagination,
|
'NP_PAGINATION' => $pagination,
|
||||||
'TOTAL_NEWS' => ($total_news == 1) ? $user->lang['VIEW_FORUM_TOPIC'] : sprintf($user->lang['VIEW_FORUM_TOPICS'], $total_news),
|
'TOTAL_NEWS' => ($total_news == 1) ? $user->lang['VIEW_FORUM_TOPIC'] : sprintf($user->lang['VIEW_FORUM_TOPICS'], $total_news),
|
||||||
'NP_PAGE_NUMBER' => on_page($total_news, $portal_config['portal_number_of_news'], $start))
|
'NP_PAGE_NUMBER' => on_page($total_news, $portal_config['portal_number_of_news'], $start))
|
||||||
@@ -169,59 +223,5 @@ if($news < 0)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$fetch_news = phpbb_fetch_posts($portal_config['portal_news_forum'], $portal_config['portal_news_permissions'], $portal_config['portal_number_of_news'], 0, 0, ($portal_config['portal_show_all_news']) ? 'news_all' : 'news', $start);
|
|
||||||
|
|
||||||
$i = $news;
|
|
||||||
$forum_id = $fetch_news[$i]['forum_id'];
|
|
||||||
$topic_id = $fetch_news[$i]['topic_id'];
|
|
||||||
$topic_tracking_info = get_complete_topic_tracking($forum_id, $topic_id, $global_announce_list = false);
|
|
||||||
$unread_topic = (isset($topic_tracking_info[$topic_id]) && $fetch_news[$i]['topic_last_post_time'] > $topic_tracking_info[$topic_id]) ? true : false;
|
|
||||||
$open_bracket = '[ ';
|
|
||||||
$close_bracket = ' ]';
|
|
||||||
$read_full = $user->lang['BACK'];
|
|
||||||
|
|
||||||
$read_full_url = (isset($_GET['np'])) ? append_sid("{$phpbb_root_path}portal.$phpEx", "np=$start#n$i") : append_sid("{$phpbb_root_path}portal.$phpEx#n$i");
|
|
||||||
$view_topic_url = append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . (($fetch_news[$i]['forum_id']) ? $fetch_news[$i]['forum_id'] : $forum_id) . '&t=' . $topic_id);
|
|
||||||
if ( $portal_config['portal_news_archive'] )
|
|
||||||
{
|
|
||||||
$pagination = generate_portal_pagination(append_sid("{$phpbb_root_path}portal.$phpEx"), $total_news, $portal_config['portal_number_of_news'], $start, ($portal_config['portal_show_all_news']) ? 'news_all' : 'news');
|
|
||||||
}
|
|
||||||
|
|
||||||
$template->assign_block_vars('news_row', array(
|
|
||||||
'ATTACH_ICON_IMG' => ($fetch_news[$i]['attachment']) ? $user->img('icon_topic_attach', $user->lang['TOTAL_ATTACHMENTS']) : '',
|
|
||||||
'FORUM_NAME' => ( $forum_id ) ? $fetch_news[$i]['forum_name'] : '',
|
|
||||||
'TITLE' => $fetch_news[$i]['topic_title'],
|
|
||||||
'POSTER' => $fetch_news[$i]['username'],
|
|
||||||
'POSTER_FULL' => $fetch_news[$i]['username_full'],
|
|
||||||
'TIME' => $fetch_news[$i]['topic_time'],
|
|
||||||
'TEXT' => $fetch_news[$i]['post_text'],
|
|
||||||
'REPLIES' => $fetch_news[$i]['topic_replies'],
|
|
||||||
'TOPIC_VIEWS' => $fetch_news[$i]['topic_views'],
|
|
||||||
'N_ID' => $i,
|
|
||||||
'U_VIEWFORUM' => append_sid("{$phpbb_root_path}viewforum.$phpEx", 'f=' . $fetch_news[$i]['forum_id']),
|
|
||||||
'U_LAST_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $fetch_news[$i]['forum_id'] . '&p=' . $fetch_news[$i]['topic_last_post_id'] . '#p' . $fetch_news[$i]['topic_last_post_id']),
|
|
||||||
'U_VIEW_COMMENTS' => append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $fetch_news[$i]['forum_id'] . '&t=' . $fetch_news[$i]['topic_id']),
|
|
||||||
'U_POST_COMMENT' => append_sid("{$phpbb_root_path}posting.$phpEx", 'mode=reply&f=' . $fetch_news[$i]['forum_id'] . '&t=' . $fetch_news[$i]['topic_id']),
|
|
||||||
'S_POLL' => $fetch_news[$i]['poll'],
|
|
||||||
'S_UNREAD_INFO' => $unread_topic,
|
|
||||||
'U_READ_FULL' => $read_full_url,
|
|
||||||
'L_READ_FULL' => $read_full,
|
|
||||||
'OPEN' => $open_bracket,
|
|
||||||
'CLOSE' => $close_bracket,
|
|
||||||
'PAGINATION' => topic_generate_pagination($fetch_news[$i]['topic_replies'], $view_topic_url),
|
|
||||||
));
|
|
||||||
|
|
||||||
if ($portal_config['portal_number_of_news'] <> 0 && $portal_config['portal_news_archive'])
|
|
||||||
{
|
|
||||||
$template->assign_vars(array(
|
|
||||||
'NP_PAGINATION' => $pagination,
|
|
||||||
'TOTAL_NEWS' => ($total_news == 1) ? $user->lang['VIEW_FORUM_TOPIC'] : sprintf($user->lang['VIEW_FORUM_TOPICS'], $total_news),
|
|
||||||
'NP_PAGE_NUMBER' => on_page($total_news, $portal_config['portal_number_of_news'], $start))
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
?>
|
?>
|
||||||
@@ -6,7 +6,13 @@
|
|||||||
</ul>
|
</ul>
|
||||||
<div class="postbody" style="width: 100%">
|
<div class="postbody" style="width: 100%">
|
||||||
<!-- BEGIN announcements_row -->
|
<!-- BEGIN announcements_row -->
|
||||||
<!-- IF not announcements_row.S_NO_TOPICS -->
|
<!-- IF announcements_row.S_NO_TOPICS -->
|
||||||
|
<div class="post bg2">
|
||||||
|
<div class="inner"><span class="corners-top"><span></span></span>
|
||||||
|
<span style="text-align: center;"><strong>{L_NO_ANNOUNCEMENTS}</strong></span>
|
||||||
|
<span class="corners-bottom"><span></span></span></div>
|
||||||
|
</div>
|
||||||
|
<!-- ELSE -->
|
||||||
<div class="post <!-- IF announcements_row.S_ROW_COUNT is odd -->bg1<!-- ELSE -->bg2<!-- ENDIF -->">
|
<div class="post <!-- IF announcements_row.S_ROW_COUNT is odd -->bg1<!-- ELSE -->bg2<!-- ENDIF -->">
|
||||||
<div class="inner"><span class="corners-top"><span></span></span>
|
<div class="inner"><span class="corners-top"><span></span></span>
|
||||||
<h4 class="first"><a name="a{announcements_row.A_ID}"></a><!-- IF announcements_row.S_UNREAD_INFO -->{NEWEST_POST_IMG}<!-- ELSE -->{READ_POST_IMG}<!-- ENDIF --> {announcements_row.ATTACH_ICON_IMG} <!-- IF announcements_row.S_POLL --> <strong>{L_POLL}: </strong><!-- ENDIF --><a href="{announcements_row.U_VIEW_COMMENTS}"><strong>{announcements_row.TITLE}</strong></a></h4>
|
<h4 class="first"><a name="a{announcements_row.A_ID}"></a><!-- IF announcements_row.S_UNREAD_INFO -->{NEWEST_POST_IMG}<!-- ELSE -->{READ_POST_IMG}<!-- ENDIF --> {announcements_row.ATTACH_ICON_IMG} <!-- IF announcements_row.S_POLL --> <strong>{L_POLL}: </strong><!-- ENDIF --><a href="{announcements_row.U_VIEW_COMMENTS}"><strong>{announcements_row.TITLE}</strong></a></h4>
|
||||||
@@ -43,12 +49,6 @@
|
|||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
<span class="corners-bottom"><span></span></span></div>
|
<span class="corners-bottom"><span></span></span></div>
|
||||||
</div>
|
</div>
|
||||||
<!-- ELSE -->
|
|
||||||
<div class="post bg2">
|
|
||||||
<div class="inner"><span class="corners-top"><span></span></span>
|
|
||||||
<span style="text-align: center;"><strong>{L_NO_ANNOUNCEMENTS}</strong></span>
|
|
||||||
<span class="corners-bottom"><span></span></span></div>
|
|
||||||
</div>
|
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
<!-- END announcements_row -->
|
<!-- END announcements_row -->
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -1,5 +1,24 @@
|
|||||||
<!-- BEGIN announcements_row -->
|
<!-- BEGIN announcements_row -->
|
||||||
<!-- IF not announcements_row.S_NO_TOPICS -->
|
<!-- IF announcements_row.S_NO_TOPICS -->
|
||||||
|
<div class="forabg">
|
||||||
|
<div class="inner">
|
||||||
|
<span class="corners-top"><span></span></span>
|
||||||
|
<ul class="topiclist">
|
||||||
|
<li class="header"><dl><dt>{L_LATEST_ANNOUNCEMENTS}</dt></dl></li>
|
||||||
|
</ul>
|
||||||
|
<ul class="topiclist topics">
|
||||||
|
<li class="bg2">
|
||||||
|
<dl>
|
||||||
|
<dt style="border-left:0px; width: 99%">
|
||||||
|
<span class="gensmall" style="font-weight: bold;">{L_NO_ANNOUNCEMENTS}</span>
|
||||||
|
</dt>
|
||||||
|
</dl>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<span class="corners-bottom"><span></span></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- ELSE -->
|
||||||
<!-- IF announcements_row.S_FIRST_ROW -->
|
<!-- IF announcements_row.S_FIRST_ROW -->
|
||||||
<div class="forabg">
|
<div class="forabg">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
@@ -46,25 +65,6 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
<!-- ELSE -->
|
|
||||||
<div class="forabg">
|
|
||||||
<div class="inner">
|
|
||||||
<span class="corners-top"><span></span></span>
|
|
||||||
<ul class="topiclist">
|
|
||||||
<li class="header"><dl><dt>{L_LATEST_ANNOUNCEMENTS}</dt></dl></li>
|
|
||||||
</ul>
|
|
||||||
<ul class="topiclist topics">
|
|
||||||
<li class="bg2">
|
|
||||||
<dl>
|
|
||||||
<dt style="border-left:0px; width: 99%">
|
|
||||||
<span class="gensmall" style="font-weight: bold;">{L_NO_ANNOUNCEMENTS}</span>
|
|
||||||
</dt>
|
|
||||||
</dl>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
<span class="corners-bottom"><span></span></span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
<!-- END announcements_row -->
|
<!-- END announcements_row -->
|
||||||
<br style="clear:both" />
|
<br style="clear:both" />
|
||||||
@@ -6,7 +6,13 @@
|
|||||||
</ul>
|
</ul>
|
||||||
<div class="postbody" style="width: 100%">
|
<div class="postbody" style="width: 100%">
|
||||||
<!-- BEGIN news_row -->
|
<!-- BEGIN news_row -->
|
||||||
<!-- IF not news_row.S_NO_TOPICS -->
|
<!-- IF news_row.S_NO_TOPICS -->
|
||||||
|
<div class="post bg2">
|
||||||
|
<div class="inner"><span class="corners-top"><span></span></span>
|
||||||
|
<span style="text-align: center;"><strong>{L_NO_NEWS}</strong></span>
|
||||||
|
<span class="corners-bottom"><span></span></span></div>
|
||||||
|
</div>
|
||||||
|
<!-- ELSE -->
|
||||||
<div class="post <!-- IF news_row.S_ROW_COUNT is odd -->bg1<!-- ELSE -->bg2<!-- ENDIF -->">
|
<div class="post <!-- IF news_row.S_ROW_COUNT is odd -->bg1<!-- ELSE -->bg2<!-- ENDIF -->">
|
||||||
<div class="inner"><span class="corners-top"><span></span></span>
|
<div class="inner"><span class="corners-top"><span></span></span>
|
||||||
<h4 class="first"><a name="n{news_row.N_ID}"></a><!-- IF news_row.S_UNREAD_INFO -->{NEWEST_POST_IMG}<!-- ELSE -->{READ_POST_IMG}<!-- ENDIF --> {news_row.ATTACH_ICON_IMG} <!-- IF news_row.S_POLL --><strong>{L_POLL}: </strong><!-- ENDIF --><a href="{news_row.U_LAST_COMMENTS}"><strong>{news_row.TITLE}</strong></a></h4>
|
<h4 class="first"><a name="n{news_row.N_ID}"></a><!-- IF news_row.S_UNREAD_INFO -->{NEWEST_POST_IMG}<!-- ELSE -->{READ_POST_IMG}<!-- ENDIF --> {news_row.ATTACH_ICON_IMG} <!-- IF news_row.S_POLL --><strong>{L_POLL}: </strong><!-- ENDIF --><a href="{news_row.U_LAST_COMMENTS}"><strong>{news_row.TITLE}</strong></a></h4>
|
||||||
@@ -27,6 +33,7 @@
|
|||||||
<div class="back2top"><a href="#wrap" class="top" title="{L_BACK_TO_TOP}">{L_BACK_TO_TOP}</a></div>
|
<div class="back2top"><a href="#wrap" class="top" title="{L_BACK_TO_TOP}">{L_BACK_TO_TOP}</a></div>
|
||||||
<!-- IF news_row.S_NOT_LAST --><br style="clear:both" /><!-- ENDIF -->
|
<!-- IF news_row.S_NOT_LAST --><br style="clear:both" /><!-- ENDIF -->
|
||||||
<!-- IF news_row.S_LAST_ROW -->
|
<!-- IF news_row.S_LAST_ROW -->
|
||||||
|
<!-- IF not news_row.S_NO_TOPICS -->
|
||||||
<!-- IF NP_PAGINATION or TOTAL_NEWS -->
|
<!-- IF NP_PAGINATION or TOTAL_NEWS -->
|
||||||
<hr class="dashed" />
|
<hr class="dashed" />
|
||||||
<div class="pagination">
|
<div class="pagination">
|
||||||
@@ -35,12 +42,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
<span class="corners-bottom"><span></span></span></div>
|
<!-- ENDIF -->
|
||||||
</div>
|
|
||||||
<!-- ELSE -->
|
|
||||||
<div class="post bg2">
|
|
||||||
<div class="inner"><span class="corners-top"><span></span></span>
|
|
||||||
<span style="text-align: center;"><strong>{L_NO_NEWS}</strong></span>
|
|
||||||
<span class="corners-bottom"><span></span></span></div>
|
<span class="corners-bottom"><span></span></span></div>
|
||||||
</div>
|
</div>
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
|
|||||||
@@ -1,5 +1,24 @@
|
|||||||
<!-- BEGIN news_row -->
|
<!-- BEGIN news_row -->
|
||||||
<!-- IF not news_row.S_NO_TOPICS -->
|
<!-- IF news_row.S_NO_TOPICS -->
|
||||||
|
<div class="forabg">
|
||||||
|
<div class="inner">
|
||||||
|
<span class="corners-top"><span></span></span>
|
||||||
|
<ul class="topiclist">
|
||||||
|
<li class="header"><dl><dt>{L_LATEST_NEWS}</dt></dl></li>
|
||||||
|
</ul>
|
||||||
|
<ul class="topiclist topics">
|
||||||
|
<li class="bg2">
|
||||||
|
<dl>
|
||||||
|
<dt style="border-left:0px; width: 99%">
|
||||||
|
<span class="gensmall" style="font-weight: bold;">{L_NO_NEWS}</span>
|
||||||
|
</dt>
|
||||||
|
</dl>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<span class="corners-bottom"><span></span></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- ELSE -->
|
||||||
<!-- IF news_row.S_FIRST_ROW -->
|
<!-- IF news_row.S_FIRST_ROW -->
|
||||||
<div class="forabg">
|
<div class="forabg">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
@@ -43,25 +62,6 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
<!-- ELSE -->
|
|
||||||
<div class="forabg">
|
|
||||||
<div class="inner">
|
|
||||||
<span class="corners-top"><span></span></span>
|
|
||||||
<ul class="topiclist">
|
|
||||||
<li class="header"><dl><dt>{L_LATEST_NEWS}</dt></dl></li>
|
|
||||||
</ul>
|
|
||||||
<ul class="topiclist topics">
|
|
||||||
<li class="bg2">
|
|
||||||
<dl>
|
|
||||||
<dt style="border-left:0px; width: 99%">
|
|
||||||
<span class="gensmall" style="font-weight: bold;">{L_NO_NEWS}</span>
|
|
||||||
</dt>
|
|
||||||
</dl>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
<span class="corners-bottom"><span></span></span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- ENDIF -->
|
<!-- ENDIF -->
|
||||||
<!-- END news_row -->
|
<!-- END news_row -->
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user