diff options
Diffstat (limited to 'phpBB/viewtopic.php')
| -rw-r--r-- | phpBB/viewtopic.php | 52 | 
1 files changed, 40 insertions, 12 deletions
| diff --git a/phpBB/viewtopic.php b/phpBB/viewtopic.php index 498088c5c8..74420a25c7 100644 --- a/phpBB/viewtopic.php +++ b/phpBB/viewtopic.php @@ -196,7 +196,7 @@ if ($db->sql_layer === 'firebird')  // The FROM-Order is quite important here, else t.* columns can not be correctly bound.  if ($post_id)  { -	$sql_array['SELECT'] .= ', p.post_approved'; +	$sql_array['SELECT'] .= ', p.post_approved, p.post_time, p.post_id';  	$sql_array['FROM'][POSTS_TABLE] = 'p';  } @@ -314,12 +314,19 @@ if ($post_id)  	}  	else  	{ -		$sql = 'SELECT COUNT(p1.post_id) AS prev_posts -			FROM ' . POSTS_TABLE . ' p1, ' . POSTS_TABLE . " p2 -			WHERE p1.topic_id = {$topic_data['topic_id']} -				AND p2.post_id = {$post_id} -				" . ((!$auth->acl_get('m_approve', $forum_id)) ? 'AND p1.post_approved = 1' : '') . ' -				AND ' . (($sort_dir == 'd') ? 'p1.post_time >= p2.post_time' : 'p1.post_time <= p2.post_time'); +		$sql = 'SELECT COUNT(p.post_id) AS prev_posts +			FROM ' . POSTS_TABLE . " p +			WHERE p.topic_id = {$topic_data['topic_id']} +				" . ((!$auth->acl_get('m_approve', $forum_id)) ? 'AND p.post_approved = 1' : ''); + +		if ($sort_dir == 'd') +		{ +			$sql .= " AND (p.post_time > {$topic_data['post_time']} OR (p.post_time = {$topic_data['post_time']} AND p.post_id >= {$topic_data['post_id']}))"; +		} +		else +		{ +			$sql .= " AND (p.post_time < {$topic_data['post_time']} OR (p.post_time = {$topic_data['post_time']} AND p.post_id <= {$topic_data['post_id']}))"; +		}  		$result = $db->sql_query($sql);  		$row = $db->sql_fetchrow($result); @@ -486,9 +493,10 @@ $s_watching_topic = array(  	'is_watching'	=> false,  ); -if (($config['email_enable'] || $config['jab_enable']) && $config['allow_topic_notify'] && $user->data['is_registered']) +if (($config['email_enable'] || $config['jab_enable']) && $config['allow_topic_notify'])  { -	watch_topic_forum('topic', $s_watching_topic, $user->data['user_id'], $forum_id, $topic_id, $topic_data['notify_status'], $start); +	$notify_status = (isset($topic_data['notify_status'])) ? $topic_data['notify_status'] : null; +	watch_topic_forum('topic', $s_watching_topic, $user->data['user_id'], $forum_id, $topic_id, $notify_status, $start, $topic_data['topic_title']);  	// Reset forum notification if forum notify is set  	if ($config['allow_forum_notify'] && $auth->acl_get('f_subscribe', $forum_id)) @@ -585,6 +593,24 @@ $server_path = (!$view) ? $phpbb_root_path : generate_board_url() . '/';  // Replace naughty words in title  $topic_data['topic_title'] = censor_text($topic_data['topic_title']); +$s_search_hidden_fields = array( +	't' => $topic_id, +	'sf' => 'msgonly', +); +if ($_SID) +{ +	$s_search_hidden_fields['sid'] = $_SID; +} + +if (!empty($_EXTRA_URL)) +{ +	foreach ($_EXTRA_URL as $url_param) +	{ +		$url_param = explode('=', $url_param, 2); +		$s_search_hidden_fields[$url_param[0]] = $url_param[1]; +	} +} +  // Send vars to template  $template->assign_vars(array(  	'FORUM_ID' 		=> $forum_id, @@ -636,7 +662,8 @@ $template->assign_vars(array(  	'S_VIEWTOPIC'			=> true,  	'S_DISPLAY_SEARCHBOX'	=> ($auth->acl_get('u_search') && $auth->acl_get('f_search', $forum_id) && $config['load_search']) ? true : false, -	'S_SEARCHBOX_ACTION'	=> append_sid("{$phpbb_root_path}search.$phpEx", 't=' . $topic_id), +	'S_SEARCHBOX_ACTION'	=> append_sid("{$phpbb_root_path}search.$phpEx"), +	'S_SEARCH_LOCAL_HIDDEN_FIELDS'	=> build_hidden_fields($s_search_hidden_fields),  	'S_DISPLAY_POST_INFO'	=> ($topic_data['forum_type'] == FORUM_POST && ($auth->acl_get('f_post', $forum_id) || $user->data['user_id'] == ANONYMOUS)) ? true : false,  	'S_DISPLAY_REPLY_INFO'	=> ($topic_data['forum_type'] == FORUM_POST && ($auth->acl_get('f_reply', $forum_id) || $user->data['user_id'] == ANONYMOUS)) ? true : false, @@ -985,7 +1012,7 @@ $sql = $db->sql_build_query('SELECT', array(  $result = $db->sql_query($sql); -$now = getdate(time() + $user->timezone + $user->dst - date('Z')); +$now = phpbb_gmgetdate(time() + $user->timezone + $user->dst);  // Posts are stored in the $rowset array while $attach_list, $user_cache  // and the global bbcode_bitfield are built @@ -1157,7 +1184,7 @@ while ($row = $db->sql_fetchrow($result))  			if (!empty($row['user_icq']))  			{ -				$user_cache[$poster_id]['icq'] = 'http://www.icq.com/people/webmsg.php?to=' . $row['user_icq']; +				$user_cache[$poster_id]['icq'] = 'http://www.icq.com/people/' . urlencode($row['user_icq']) . '/';  				$user_cache[$poster_id]['icq_status_img'] = '<img src="http://web.icq.com/whitepages/online?icq=' . $row['user_icq'] . '&img=5" width="18" height="18" alt="" />';  			}  			else @@ -1547,6 +1574,7 @@ for ($i = 0, $end = sizeof($post_list); $i < $end; ++$i)  		'U_WARN'			=> ($auth->acl_get('m_warn') && $poster_id != $user->data['user_id'] && $poster_id != ANONYMOUS) ? append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=warn&mode=warn_post&f=' . $forum_id . '&p=' . $row['post_id'], true, $user->session_id) : '',  		'POST_ID'			=> $row['post_id'], +		'POST_NUMBER'		=> $i + $start + 1,  		'POSTER_ID'			=> $poster_id,  		'S_HAS_ATTACHMENTS'	=> (!empty($attachments[$row['post_id']])) ? true : false, | 
