mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-26 13:16:14 +01:00 
			
		
		
		
	- changed mcp_front to be more moderator friendly - able to change the forum in mcp_queue (for moderators moderating more than one forum) git-svn-id: file:///svn/phpbb/trunk@4937 89ea8834-ac86-4346-8a33-228a782c2dd0
		
			
				
	
	
		
			239 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			239 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| // -------------------------------------------------------------
 | |
| //
 | |
| // $Id$
 | |
| //
 | |
| // FILENAME  : mcp_forum.php
 | |
| // STARTED   : Thu Jul 08, 2004
 | |
| // COPYRIGHT : © 2004 phpBB Group
 | |
| // WWW       : http://www.phpbb.com/
 | |
| // LICENCE   : GPL vs2.0 [ see /docs/COPYING ] 
 | |
| // 
 | |
| // -------------------------------------------------------------
 | |
| 
 | |
| //
 | |
| // TODO:
 | |
| //
 | |
| 
 | |
| function mcp_forum_view($id, $mode, $action, $url, $forum_info)
 | |
| {
 | |
| 	global $SID, $phpEx, $phpbb_root_path, $config;
 | |
| 	global $template, $db, $user, $auth;
 | |
| 	global $_POST, $_REQUEST;
 | |
| 
 | |
| 	if ($action == 'merge_select')
 | |
| 	{
 | |
| 		// Fixes a "bug" that makes forum_view use the same ordering as topic_view
 | |
| 		unset($_POST['sk'], $_POST['sd'], $_REQUEST['sk'], $_REQUEST['sd']);
 | |
| 	}
 | |
| 
 | |
| 	$forum_id = $forum_info['forum_id'];
 | |
| 	$start = request_var('start', 0);
 | |
| 	$topic_id_list = request_var('topic_id_list', 0);
 | |
| 	$post_id_list = request_var('post_id_list', 0);
 | |
| 	$topic_id = request_var('t', 0);
 | |
| 
 | |
| 	// Resync Topics
 | |
| 	if ($action == 'resync')
 | |
| 	{
 | |
| 		$topic_ids = get_array('topic_id_list', 0);
 | |
| 
 | |
| 		if (!$topic_ids)
 | |
| 		{
 | |
| 			$template->assign_var('MESSAGE', $user->lang['NO_TOPIC_SELECTED']);
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			mcp_resync_topics($topic_ids);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	$selected_ids = '';
 | |
| 	if ($post_id_list)
 | |
| 	{
 | |
| 		foreach ($post_id_list as $num => $post_id)
 | |
| 		{
 | |
| 			$selected_ids .= '&post_id_list[' . $num . ']=' . $post_id;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	make_jumpbox($url . "&action=$action&mode=$mode", $forum_id . (($action == 'merge_select') ? $selected_ids : ''), false, 'm_');
 | |
| 
 | |
| 	$topics_per_page = ($forum_info['forum_topics_per_page']) ? $forum_info['forum_topics_per_page'] : $config['topics_per_page'];
 | |
| 
 | |
| 	mcp_sorting('viewforum', $sort_days, $sort_key, $sort_dir, $sort_by_sql, $sort_order_sql, $total, $forum_id);
 | |
| 	$forum_topics = ($total == -1) ? $forum_info['forum_topics'] : $total;
 | |
| 	$limit_time_sql = ($sort_days) ? 'AND t.topic_last_post_time >= ' . (time() - ($sort_days * 86400)) : '';
 | |
| 
 | |
| 	$template->assign_vars(array(
 | |
| 		'FORUM_NAME'			=> $forum_info['forum_name'],
 | |
| 
 | |
| 		'REPORTED_IMG'			=> $user->img('icon_reported', 'TOPIC_REPORTED'),
 | |
| 		'UNAPPROVED_IMG'		=> $user->img('icon_unapproved', 'TOPIC_UNAPPROVED'),
 | |
| 
 | |
| 		'S_CAN_DELETE'			=> $auth->acl_get('m_delete', $forum_id),
 | |
| 		'S_CAN_MOVE'			=> $auth->acl_get('m_move', $forum_id),
 | |
| 		'S_CAN_FORK'			=> $auth->acl_get('m_', $forum_id),
 | |
| 		'S_CAN_LOCK'			=> $auth->acl_get('m_lock', $forum_id),
 | |
| 		'S_CAN_SYNC'			=> $auth->acl_get('m_', $forum_id),
 | |
| 		'S_CAN_APPROVE'			=> $auth->acl_get('m_approve', $forum_id),
 | |
| 
 | |
| 		'U_VIEW_FORUM'			=> "viewforum.$phpEx$SID&f=" . $forum_id,
 | |
| 		'S_MCP_ACTION'			=> $url . "&action=$action&mode=$mode&start=$start" . (($action == 'merge_select') ? $selected_ids : ''),
 | |
| 
 | |
| 		'PAGINATION'			=> generate_pagination($url . "&action=$action&mode=$mode" . (($action == 'merge_select') ? $selected_ids : ''), $forum_topics, $topics_per_page, $start),
 | |
| 		'PAGE_NUMBER'			=> on_page($forum_topics, $topics_per_page, $start),
 | |
| 		'TOTAL'					=> $forum_topics)
 | |
| 	);
 | |
| 
 | |
| 	$topic_rows = array();
 | |
| 
 | |
| 	$sql = 'SELECT t.*
 | |
| 		FROM ' . TOPICS_TABLE . " t
 | |
| 		WHERE (t.forum_id = $forum_id OR t.forum_id = 0)
 | |
| 			" . (($auth->acl_get('m_approve', $forum_id)) ? '' : 'AND t.topic_approved = 1') . "
 | |
| 			AND t.topic_type IN (" . POST_ANNOUNCE . ", " . POST_GLOBAL . ")
 | |
| 			$limit_time_sql
 | |
| 		ORDER BY $sort_order_sql";
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	while ($row = $db->sql_fetchrow($result))
 | |
| 	{
 | |
| 		$topic_rows[] = $row;
 | |
| 	}
 | |
| 	$db->sql_freeresult($result);
 | |
| 
 | |
| 	$sql = 'SELECT t.*
 | |
| 		FROM ' . TOPICS_TABLE . " t
 | |
| 		WHERE t.forum_id = $forum_id
 | |
| 			" . (($auth->acl_get('m_approve', $forum_id)) ? '' : 'AND t.topic_approved = 1') . '
 | |
| 			AND t.topic_type IN (' . POST_NORMAL . ', ' . POST_STICKY . ")
 | |
| 			$limit_time_sql
 | |
| 		ORDER BY t.topic_type DESC, $sort_order_sql";
 | |
| 	$result = $db->sql_query_limit($sql, $topics_per_page, $start);
 | |
| 
 | |
| 	while ($row = $db->sql_fetchrow($result))
 | |
| 	{
 | |
| 		$topic_rows[] = $row;
 | |
| 	}
 | |
| 	$db->sql_freeresult($result);
 | |
| 
 | |
| 	foreach ($topic_rows as $row)
 | |
| 	{
 | |
| 		$topic_title = '';
 | |
| 
 | |
| 		if ($auth->acl_get('m_approve', $row['forum_id']))
 | |
| 		{
 | |
| 			$row['topic_replies'] = $row['topic_replies_real'];
 | |
| 		}
 | |
| 
 | |
| 		if ($row['topic_status'] == ITEM_LOCKED)
 | |
| 		{
 | |
| 			$folder_img = $user->img('folder_locked', 'VIEW_TOPIC_LOCKED');
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			if ($row['topic_type'] == POST_ANNOUNCE || $row['topic_type'] == POST_GLOBAL)
 | |
| 			{
 | |
| 				$folder_img = $user->img('folder_announce', 'VIEW_TOPIC_ANNOUNCEMENT');
 | |
| 			}
 | |
| 			else if ($row['topic_type'] == POST_STICKY)
 | |
| 			{
 | |
| 				$folder_img = $user->img('folder_sticky', 'VIEW_TOPIC_STICKY');
 | |
| 			}
 | |
| 			else if ($row['topic_status'] == ITEM_MOVED)
 | |
| 			{
 | |
| 				$folder_img = $user->img('folder_moved', 'VIEW_TOPIC_MOVED');
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				$folder_img = $user->img('folder', 'NO_NEW_POSTS');
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		if ($row['topic_type'] == POST_ANNOUNCE || $row['topic_type'] == POST_GLOBAL)
 | |
| 		{
 | |
| 			$topic_type = $user->lang['VIEW_TOPIC_ANNOUNCEMENT'] . ' ';
 | |
| 		}
 | |
| 		else if ($row['topic_type'] == POST_STICKY)
 | |
| 		{
 | |
| 			$topic_type = $user->lang['VIEW_TOPIC_STICKY'] . ' ';
 | |
| 		}
 | |
| 		else if ($row['topic_status'] == ITEM_MOVED)
 | |
| 		{
 | |
| 			$topic_type = $user->lang['VIEW_TOPIC_MOVED'] . ' ';
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			$topic_type = '';
 | |
| 		}
 | |
| 
 | |
| 		if (intval($row['poll_start']))
 | |
| 		{
 | |
| 			$topic_type .= $user->lang['VIEW_TOPIC_POLL'] . ' ';
 | |
| 		}
 | |
| 
 | |
| 		$topic_title = censor_text($row['topic_title']);
 | |
| 			
 | |
| 		$template->assign_block_vars('topicrow', array(
 | |
| 			'U_VIEW_TOPIC'		=> "mcp.$phpEx$SID&f=$forum_id&t={$row['topic_id']}&mode=topic_view",
 | |
| 
 | |
| 			'S_SELECT_TOPIC'	=> ($action == 'merge_select' && $row['topic_id'] != $topic_id) ? true : false,
 | |
| 			'U_SELECT_TOPIC'	=> $url . '&mode=topic_view&action=merge&to_topic_id=' . $row['topic_id'] . $selected_ids,
 | |
| 			'U_MCP_QUEUE'		=> $url . '&i=queue&mode=approve_details&t=' . $row['topic_id'],
 | |
| 			'U_MCP_REPORT'		=> "mcp.$phpEx$SID&i=main&mode=topic_view&t={$row['topic_id']}&action=reports",
 | |
| 
 | |
| 			'ATTACH_ICON_IMG'	=> ($auth->acl_gets('f_download', 'u_download', $row['forum_id']) && $row['topic_attachment']) ? $user->img('icon_attach', sprintf($user->lang['TOTAL_ATTACHMENTS'], $row['topic_attachment'])) : '',
 | |
| 			'TOPIC_FOLDER_IMG'	=>	$folder_img,
 | |
| 			'TOPIC_TYPE'		=>	$topic_type,
 | |
| 			'TOPIC_TITLE'		=>	$topic_title,
 | |
| 			'REPLIES'			=>	$row['topic_replies'],
 | |
| 			'LAST_POST_TIME'	=>	$user->format_date($row['topic_last_post_time']),
 | |
| 			'TOPIC_ID'			=>	$row['topic_id'],
 | |
| 			'S_TOPIC_CHECKED'	=>	($topic_id_list && in_array($row['topic_id'], $topic_id_list)) ? 'checked="checked" ' : '',
 | |
| 
 | |
| 			'S_TOPIC_REPORTED'	=>	($row['topic_reported']) ? true : false,
 | |
| 			'S_TOPIC_UNAPPROVED'=>	($row['topic_approved']) ? false : true)
 | |
| 		);
 | |
| 	}
 | |
| 	unset($topic_rows);
 | |
| }
 | |
| 
 | |
| function mcp_resync_topics($topic_ids)
 | |
| {
 | |
| 	global $auth, $db, $template, $phpEx, $user, $SID, $phpbb_root_path;
 | |
| 
 | |
| 	if (!($forum_id = check_ids($topic_ids, TOPICS_TABLE, 'topic_id', 'm_')))
 | |
| 	{
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	if (!sizeof($topic_ids))
 | |
| 	{
 | |
| 		$template->assign_var('MESSAGE', $user->lang['NO_TOPIC_SELECTED']);
 | |
| 		return;
 | |
| 	}
 | |
| 	
 | |
| 	// Sync everything and perform extra checks separately
 | |
| 	sync('topic_reported', 'topic_id', $topic_ids, false, true);
 | |
| 	sync('topic_attachment', 'topic_id', $topic_ids, false, true);
 | |
| 	sync('topic', 'topic_id', $topic_ids, true, false);
 | |
| 
 | |
| 	$sql = 'SELECT topic_id, forum_id, topic_title
 | |
| 		FROM ' . TOPICS_TABLE . '
 | |
| 		WHERE topic_id IN (' . implode(', ', $topic_ids) . ')';
 | |
| 	$result = $db->sql_query($sql);
 | |
| 
 | |
| 	// Log this action
 | |
| 	while ($row = $db->sql_fetchrow($result))
 | |
| 	{
 | |
| 		add_log('mod', $row['forum_id'], $row['topic_id'], 'LOG_TOPIC_RESYNC', $row['topic_title']);
 | |
| 	}
 | |
| 
 | |
| 	$msg = (sizeof($topic_ids) == 1) ? $user->lang['TOPIC_RESYNC_SUCCESS'] : $user->lang['TOPICS_RESYNC_SUCCESS'];
 | |
| 	$template->assign_var('MESSAGE', $msg);
 | |
| 
 | |
| 	return;
 | |
| }
 | |
| 
 | |
| ?>
 |