diff options
Diffstat (limited to 'phpBB/includes/functions.php')
| -rw-r--r-- | phpBB/includes/functions.php | 119 | 
1 files changed, 112 insertions, 7 deletions
| diff --git a/phpBB/includes/functions.php b/phpBB/includes/functions.php index ebd676b17a..8c29bc7171 100644 --- a/phpBB/includes/functions.php +++ b/phpBB/includes/functions.php @@ -2679,7 +2679,7 @@ function confirm_box($check, $title = '', $hidden = '', $html_body = 'confirm_bo  	}  	else  	{ -		page_header(((!isset($user->lang[$title])) ? $user->lang['CONFIRM'] : $user->lang[$title]), false); +		page_header((!isset($user->lang[$title])) ? $user->lang['CONFIRM'] : $user->lang[$title]);  	}  	$template->set_filenames(array( @@ -2956,7 +2956,7 @@ function login_box($redirect = '', $l_explain = '', $l_success = '', $admin = fa  		'PASSWORD_CREDENTIAL'	=> ($admin) ? 'password_' . $credential : 'password',  	)); -	page_header($user->lang['LOGIN'], false); +	page_header($user->lang['LOGIN']);  	$template->set_filenames(array(  		'body' => 'login_body.html') @@ -3032,7 +3032,7 @@ function login_forum_box($forum_data)  		$template->assign_var('LOGIN_ERROR', $user->lang['WRONG_PASSWORD']);  	} -	page_header($user->lang['LOGIN'], false); +	page_header($user->lang['LOGIN']);  	$template->assign_vars(array(  		'FORUM_NAME'			=> isset($forum_data['forum_name']) ? $forum_data['forum_name'] : '', @@ -3945,7 +3945,7 @@ function msg_handler($errno, $msg_text, $errfile, $errline)  				}  				else  				{ -					page_header($msg_title, false); +					page_header($msg_title);  				}  			} @@ -4620,9 +4620,95 @@ function phpbb_build_hidden_fields_for_query_params($request, $exclude = null)  }  /** +* Get user avatar +* +* @param array $user_row Row from the users table +* @param string $alt Optional language string for alt tag within image, can be a language key or text +* @param bool $ignore_config Ignores the config-setting, to be still able to view the avatar in the UCP +* +* @return string Avatar html +*/ +function phpbb_get_user_avatar($user_row, $alt = 'USER_AVATAR', $ignore_config = false) +{ +	$row = \phpbb\avatar\manager::clean_row($user_row, 'user'); +	return phpbb_get_avatar($row, $alt, $ignore_config); +} + +/** +* Get group avatar +* +* @param array $group_row Row from the groups table +* @param string $alt Optional language string for alt tag within image, can be a language key or text +* @param bool $ignore_config Ignores the config-setting, to be still able to view the avatar in the UCP +* +* @return string Avatar html +*/ +function phpbb_get_group_avatar($user_row, $alt = 'GROUP_AVATAR', $ignore_config = false) +{ +	$row = \phpbb\avatar\manager::clean_row($user_row, 'group'); +	return phpbb_get_avatar($row, $alt, $ignore_config); +} + +/** +* Get avatar +* +* @param array $row Row cleaned by \phpbb\avatar\driver\driver::clean_row +* @param string $alt Optional language string for alt tag within image, can be a language key or text +* @param bool $ignore_config Ignores the config-setting, to be still able to view the avatar in the UCP +* +* @return string Avatar html +*/ +function phpbb_get_avatar($row, $alt, $ignore_config = false) +{ +	global $user, $config, $cache, $phpbb_root_path, $phpEx; +	global $request; +	global $phpbb_container; + +	if (!$config['allow_avatar'] && !$ignore_config) +	{ +		return ''; +	} + +	$avatar_data = array( +		'src' => $row['avatar'], +		'width' => $row['avatar_width'], +		'height' => $row['avatar_height'], +	); + +	$phpbb_avatar_manager = $phpbb_container->get('avatar.manager'); +	$driver = $phpbb_avatar_manager->get_driver($row['avatar_type'], $ignore_config); +	$html = ''; + +	if ($driver) +	{ +		$html = $driver->get_custom_html($user, $row, $alt); +		if (!empty($html)) +		{ +			return $html; +		} + +		$avatar_data = $driver->get_data($row, $ignore_config); +	} +	else +	{ +		$avatar_data['src'] = ''; +	} + +	if (!empty($avatar_data['src'])) +	{ +		$html = '<img src="' . $avatar_data['src'] . '" ' . +			($avatar_data['width'] ? ('width="' . $avatar_data['width'] . '" ') : '') . +			($avatar_data['height'] ? ('height="' . $avatar_data['height'] . '" ') : '') . +			'alt="' . ((!empty($user->lang[$alt])) ? $user->lang[$alt] : $alt) . '" />'; +	} + +	return $html; +} + +/**  * Generate page header  */ -function page_header($page_title = '', $display_online_list = true, $item_id = 0, $item = 'forum') +function page_header($page_title = '', $display_online_list = false, $item_id = 0, $item = 'forum')  {  	global $db, $config, $template, $SID, $_SID, $_EXTRA_URL, $user, $auth, $phpEx, $phpbb_root_path;  	global $phpbb_dispatcher, $request, $phpbb_container, $phpbb_admin_path; @@ -4686,7 +4772,7 @@ function page_header($page_title = '', $display_online_list = true, $item_id = 0  	if ($user->data['user_id'] != ANONYMOUS)  	{  		$u_login_logout = append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=logout', true, $user->session_id); -		$l_login_logout = sprintf($user->lang['LOGOUT_USER'], $user->data['username']); +		$l_login_logout = $user->lang['LOGOUT'];  	}  	else  	{ @@ -4830,6 +4916,7 @@ function page_header($page_title = '', $display_online_list = true, $item_id = 0  	// The following assigns all _common_ variables that may be used at any point in a template.  	$template->assign_vars(array( +		'CURRENT_USER_AVATAR'	=> phpbb_get_user_avatar($user->data),  		'SITENAME'						=> $config['sitename'],  		'SITE_DESCRIPTION'				=> $config['site_desc'],  		'PAGE_TITLE'					=> $page_title, @@ -4859,6 +4946,7 @@ function page_header($page_title = '', $display_online_list = true, $item_id = 0  		'SESSION_ID'		=> $user->session_id,  		'ROOT_PATH'			=> $web_path,  		'BOARD_URL'			=> $board_url, +		'USERNAME_FULL'		=> get_username_string('full', $user->data['user_id'], $user->data['username'], $user->data['user_colour']),  		'L_LOGIN_LOGOUT'	=> $l_login_logout,  		'L_INDEX'			=> ($config['board_index_text'] !== '') ? $config['board_index_text'] : $user->lang['FORUM_INDEX'], @@ -4875,6 +4963,7 @@ function page_header($page_title = '', $display_online_list = true, $item_id = 0  		'U_SITE_HOME'			=> $config['site_home_url'],  		'U_REGISTER'			=> append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=register'),  		'U_PROFILE'				=> append_sid("{$phpbb_root_path}ucp.$phpEx"), +		'U_USER_PROFILE'		=> get_username_string('profile', $user->data['user_id'], $user->data['username'], $user->data['user_colour']),  		'U_MODCP'				=> append_sid("{$phpbb_root_path}mcp.$phpEx", false, true, $user->session_id),  		'U_FAQ'					=> append_sid("{$phpbb_root_path}faq.$phpEx"),  		'U_SEARCH_SELF'			=> append_sid("{$phpbb_root_path}search.$phpEx", 'search_id=egosearch'), @@ -4883,7 +4972,7 @@ function page_header($page_title = '', $display_online_list = true, $item_id = 0  		'U_SEARCH_UNREAD'		=> append_sid("{$phpbb_root_path}search.$phpEx", 'search_id=unreadposts'),  		'U_SEARCH_ACTIVE_TOPICS'=> append_sid("{$phpbb_root_path}search.$phpEx", 'search_id=active_topics'),  		'U_DELETE_COOKIES'		=> append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=delete_cookies'), -		'U_TEAM'				=> ($user->data['user_id'] != ANONYMOUS && !$auth->acl_get('u_viewprofile')) ? '' : append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=leaders'), +		'U_TEAM'				=> ($user->data['user_id'] != ANONYMOUS && !$auth->acl_get('u_viewprofile')) ? '' : append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=team'),  		'U_TERMS_USE'			=> append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=terms'),  		'U_PRIVACY'				=> append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=privacy'),  		'U_RESTORE_PERMISSIONS'	=> ($user->data['user_perm_from'] && $auth->acl_get('a_switchperm')) ? append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=restore_perm') : '', @@ -4957,6 +5046,22 @@ function page_header($page_title = '', $display_online_list = true, $item_id = 0  		'SITE_LOGO_IMG'			=> $user->img('site_logo'),  	)); +	/** +	* Execute code and/or overwrite _common_ template variables after they have been assigned. +	* +	* @event core.page_header_after +	* @var	string	page_title			Page title +	* @var	bool	display_online_list		Do we display online users list +	* @var	string	item				Restrict online users to a certain +	*									session item, e.g. forum for +	*									session_forum_id +	* @var	int		item_id				Restrict online users to item id +	* +	* @since 3.1.0-b3 +	*/ +	$vars = array('page_title', 'display_online_list', 'item_id', 'item'); +	extract($phpbb_dispatcher->trigger_event('core.page_header_after', compact($vars))); +  	// application/xhtml+xml not used because of IE  	header('Content-type: text/html; charset=UTF-8'); | 
