mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-26 13:16:14 +01:00 
			
		
		
		
	More user search fixes ...
git-svn-id: file:///svn/phpbb/trunk@2768 89ea8834-ac86-4346-8a33-228a782c2dd0
This commit is contained in:
		| @@ -401,7 +401,7 @@ switch ( $mode ) | |||||||
| 		$l_unban_explain = $lang['Unban_username_explain']; | 		$l_unban_explain = $lang['Unban_username_explain']; | ||||||
| 		$l_ban_cell = $lang['Username']; | 		$l_ban_cell = $lang['Username']; | ||||||
| 		$l_no_ban_cell = $lang['No_banned_users']; | 		$l_no_ban_cell = $lang['No_banned_users']; | ||||||
| 		$s_submit_extra = '<input type="submit" name="usersubmit" value="' . $lang['Find_username'] . '" class="liteoption" onClick="window.open(\'../search.' . $phpEx . $SID . '&mode=searchuser&field=ban\', \'_phpbbsearch\', \'HEIGHT=420,resizable=yes,scrollbars=yes,WIDTH=650\');return false;" />'; | 		$s_submit_extra = '<input type="submit" name="usersubmit" value="' . $lang['Find_username'] . '" class="liteoption" onClick="window.open(\'../search.' . $phpEx . $SID . '&mode=searchuser&field=ban\', \'_phpbbsearch\', \'HEIGHT=500,resizable=yes,scrollbars=yes,WIDTH=650\');return false;" />'; | ||||||
|  |  | ||||||
| 		break; | 		break; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -760,7 +760,7 @@ $lang['Search_keywords'] = 'Search for Keywords'; | |||||||
| $lang['Search_keywords_explain'] = 'You can use <u>AND</u> to define words which must be in the results, <u>OR</u> to define words which may be in the result and <u>NOT</u> to define words which should not be in the result. Use * as a wildcard for partial matches'; | $lang['Search_keywords_explain'] = 'You can use <u>AND</u> to define words which must be in the results, <u>OR</u> to define words which may be in the result and <u>NOT</u> to define words which should not be in the result. Use * as a wildcard for partial matches'; | ||||||
| $lang['Search_author'] = 'Search for Author'; | $lang['Search_author'] = 'Search for Author'; | ||||||
| $lang['Search_author_explain'] = 'Use * as a wildcard for partial matches'; | $lang['Search_author_explain'] = 'Use * as a wildcard for partial matches'; | ||||||
| $lang['Find_username_explain'] = 'Use this form to search for specific usernames. You do not need to fill out all fields, to partialy match data use * as a wildcard. When entering dates use the format yyyy-mm-dd, e.g. 2002-01-01.'; | $lang['Find_username_explain'] = 'Use this form to search for specific usernames. You do not need to fill out all fields, to partialy match data use * as a wildcard. When entering dates use the format yyyy-mm-dd, e.g. 2002-01-01. Click the username to automatically enter it into the form you are viewing (several usernames may be accepted depending on the form itself).'; | ||||||
| $lang['Last_active'] = 'Last active'; | $lang['Last_active'] = 'Last active'; | ||||||
|  |  | ||||||
| $lang['Search_for_any'] = 'Search for any terms or use query as entered'; | $lang['Search_for_any'] = 'Search for any terms or use query as entered'; | ||||||
|   | |||||||
| @@ -1304,24 +1304,26 @@ function username_search() | |||||||
| 	global $db, $board_config, $template, $acl, $lang, $theme; | 	global $db, $board_config, $template, $acl, $lang, $theme; | ||||||
| 	global $starttime; | 	global $starttime; | ||||||
|  |  | ||||||
| 	$field_name = ( isset($HTTP_GET_VARS['field']) ) ? $HTTP_GET_VARS['field'] : 'username'; | 	$field = ( isset($HTTP_GET_VARS['field']) ) ? $HTTP_GET_VARS['field'] : 'username'; | ||||||
| 	$start = ( isset($HTTP_GET_VARS['start']) ) ? intval($HTTP_GET_VARS['start']) : 0; | 	$start = ( isset($HTTP_GET_VARS['start']) ) ? intval($HTTP_GET_VARS['start']) : 0; | ||||||
|  |  | ||||||
| 	$sort_order = ( !empty($HTTP_POST_VARS['sort_order']) ) ? $HTTP_POST_VARS['sort_order'] : 'd'; | 	$sort_order = ( !empty($HTTP_POST_VARS['sort_order']) ) ? $HTTP_POST_VARS['sort_order'] : ( ( !empty($HTTP_GET_VARS['sort_order']) ) ? $HTTP_GET_VARS['sort_order'] : 'd' ); | ||||||
| 	$sort_by = ( !empty($HTTP_POST_VARS['sort_by']) ) ? intval($HTTP_POST_VARS['sort_by']) : 4; |  | ||||||
| 	$joined_select = ( !empty($HTTP_POST_VARS['joined_select']) ) ? $HTTP_POST_VARS['joined_select'] : 'lt'; |  | ||||||
| 	$active_select = ( !empty($HTTP_POST_VARS['active_select']) ) ? $HTTP_POST_VARS['active_select'] : 'lt'; |  | ||||||
| 	$count_select = ( !empty($HTTP_POST_VARS['count_select']) ) ? $HTTP_POST_VARS['count_select'] : 'lt'; |  | ||||||
|  |  | ||||||
| 	$username = ( !empty($HTTP_POST_VARS['username']) ) ? $HTTP_POST_VARS['username'] : ''; | 	$sort_by = ( !empty($HTTP_POST_VARS['sort_by']) ) ? intval($HTTP_POST_VARS['sort_by']) : ( ( !empty($HTTP_GET_VARS['sort_by']) ) ? $HTTP_GET_VARS['sort_by'] : '4' ); | ||||||
| 	$email = ( !empty($HTTP_POST_VARS['email']) ) ? $HTTP_POST_VARS['email'] : ''; |  | ||||||
| 	$icq = ( !empty($HTTP_POST_VARS['icq']) ) ? intval($HTTP_POST_VARS['icq']) : ''; | 	$joined_select = ( !empty($HTTP_POST_VARS['joined_select']) ) ? $HTTP_POST_VARS['joined_select'] : ( ( !empty($HTTP_GET_VARS['joined_select']) ) ? $HTTP_GET_VARS['joined_select'] : 'lt' ); | ||||||
| 	$aim = ( !empty($HTTP_POST_VARS['aim']) ) ? $HTTP_POST_VARS['aim'] : ''; | 	$active_select = ( !empty($HTTP_POST_VARS['active_select']) ) ? $HTTP_POST_VARS['active_select'] : ( ( !empty($HTTP_GET_VARS['active_select']) ) ? $HTTP_GET_VARS['active_select'] : 'lt' ); | ||||||
| 	$yahoo = ( !empty($HTTP_POST_VARS['yahoo']) ) ? $HTTP_POST_VARS['yahoo'] : ''; | 	$count_select = ( !empty($HTTP_POST_VARS['count_select']) ) ? $HTTP_POST_VARS['count_select'] : ( ( !empty($HTTP_GET_VARS['count_select']) ) ? $HTTP_GET_VARS['count_select'] : 'eq' ); | ||||||
| 	$msn = ( !empty($HTTP_POST_VARS['msn']) ) ? $HTTP_POST_VARS['msn'] : ''; |  | ||||||
| 	$joined = ( !empty($HTTP_POST_VARS['joined']) ) ? explode('-', $HTTP_POST_VARS['joined']) : ''; | 	$username = ( !empty($HTTP_POST_VARS['username']) ) ? $HTTP_POST_VARS['username'] : ( ( !empty($HTTP_GET_VARS['username']) ) ? $HTTP_GET_VARS['username'] : '' ); | ||||||
| 	$active = ( !empty($HTTP_POST_VARS['active']) ) ? explode('-', $HTTP_POST_VARS['active']) : ''; | 	$email = ( !empty($HTTP_POST_VARS['email']) ) ? $HTTP_POST_VARS['email'] : ( ( !empty($HTTP_GET_VARS['email']) ) ? $HTTP_GET_VARS['email'] : '' ); | ||||||
| 	$count = ( !empty($HTTP_POST_VARS['count']) ) ? intval($HTTP_POST_VARS['count']) : ''; | 	$icq = ( !empty($HTTP_POST_VARS['icq']) ) ? intval($HTTP_POST_VARS['icq']) : ( ( !empty($HTTP_GET_VARS['icq']) ) ? $HTTP_GET_VARS['icq'] : '' ); | ||||||
|  | 	$aim = ( !empty($HTTP_POST_VARS['aim']) ) ? $HTTP_POST_VARS['aim'] : ( ( !empty($HTTP_GET_VARS['aim']) ) ? $HTTP_GET_VARS['aim'] : '' ); | ||||||
|  | 	$yahoo = ( !empty($HTTP_POST_VARS['yahoo']) ) ? $HTTP_POST_VARS['yahoo'] : ( ( !empty($HTTP_GET_VARS['yahoo']) ) ? $HTTP_GET_VARS['yahoo'] : '' ); | ||||||
|  | 	$msn = ( !empty($HTTP_POST_VARS['msn']) ) ? $HTTP_POST_VARS['msn'] : ( ( !empty($HTTP_GET_VARS['msn']) ) ? $HTTP_GET_VARS['msn'] : '' ); | ||||||
|  | 	$joined = ( !empty($HTTP_POST_VARS['joined']) ) ? explode('-', $HTTP_POST_VARS['joined']) : ( ( !empty($HTTP_GET_VARS['joined']) ) ? explode('-', $HTTP_GET_VARS['joined']) : array() ); | ||||||
|  | 	$active = ( !empty($HTTP_POST_VARS['active']) ) ? explode('-', $HTTP_POST_VARS['active']) : ( ( !empty($HTTP_GET_VARS['active']) ) ? explode('-', $HTTP_GET_VARS['active']) : array() ); | ||||||
|  | 	$count = ( !empty($HTTP_POST_VARS['count']) ) ? intval($HTTP_POST_VARS['count']) : ( ( !empty($HTTP_GET_VARS['count']) ) ? $HTTP_GET_VARS['count'] : '' ); | ||||||
|  |  | ||||||
| 	// | 	// | ||||||
| 	// | 	// | ||||||
| @@ -1342,8 +1344,6 @@ function username_search() | |||||||
| 		$s_sort_order .= '<option value="' . $key . '"' . $selected . '>' . $value . '</option>'; | 		$s_sort_order .= '<option value="' . $key . '"' . $selected . '>' . $value . '</option>'; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	$sort_order = ( $sort_order == 'a' ) ? 'ASC' : 'DESC'; |  | ||||||
|  |  | ||||||
| 	$find_count = array('lt' => $lang['Less_than'], 'eq' => $lang['Equal_to'], 'gt' => $lang['More_than']); | 	$find_count = array('lt' => $lang['Less_than'], 'eq' => $lang['Equal_to'], 'gt' => $lang['More_than']); | ||||||
| 	$s_find_count = ''; | 	$s_find_count = ''; | ||||||
| 	foreach ( $find_count as $key => $value ) | 	foreach ( $find_count as $key => $value ) | ||||||
| @@ -1381,28 +1381,26 @@ function username_search() | |||||||
| 		$where_sql .= ( $aim ) ? " AND user_aim LIKE '" . str_replace('*', '%', $aim) ."' " : ''; | 		$where_sql .= ( $aim ) ? " AND user_aim LIKE '" . str_replace('*', '%', $aim) ."' " : ''; | ||||||
| 		$where_sql .= ( $yahoo ) ? " AND user_yim LIKE '" . str_replace('*', '%', $yahoo) ."' " : ''; | 		$where_sql .= ( $yahoo ) ? " AND user_yim LIKE '" . str_replace('*', '%', $yahoo) ."' " : ''; | ||||||
| 		$where_sql .= ( $msn ) ? " AND user_msnm LIKE '" . str_replace('*', '%', $msn) ."' " : ''; | 		$where_sql .= ( $msn ) ? " AND user_msnm LIKE '" . str_replace('*', '%', $msn) ."' " : ''; | ||||||
| 		$where_sql .= ( $joined ) ? " AND user_regdate " . $key_match[$joined_select] . " " . gmmktime(0, 0, 0, $joined[1], $joined[2], $joined[0]) : ''; | 		$where_sql .= ( $joined ) ? " AND user_regdate " . $key_match[$joined_select] . " " . gmmktime(0, 0, 0, intval($joined[1]), intval($joined[2]), intval($joined[0])) : ''; | ||||||
| 		$where_sql .= ( $count ) ? " AND user_posts " . $key_match[$count_select] . " $count " : ''; | 		$where_sql .= ( $count ) ? " AND user_posts " . $key_match[$count_select] . " $count " : ''; | ||||||
| 		$where_sql .= ( $active ) ? " AND user_lastvisit " . $key_match[$active_select] . " " . gmmktime(0, 0, 0, $active[1], $active[2], $active[0]) : ''; | 		$where_sql .= ( $active ) ? " AND user_lastvisit " . $key_match[$active_select] . " " . gmmktime(0, 0, 0, $active[1], intval($active[2]), intval($active[0])) : ''; | ||||||
|  |  | ||||||
| 		$order_by = $sort_by_types[$sort_by] . "  $sort_order "; | 		$order_by = $sort_by_types[$sort_by] . "  " . ( ( $sort_order == 'a' ) ? 'ASC' : 'DESC' ); | ||||||
| 	} | 	} | ||||||
| 	else | 	else | ||||||
| 	{ | 	{ | ||||||
| 		$order_by = "user_lastvisit $sort_order "; | 		$order_by = "user_lastvisit DESC "; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	$sql = "SELECT COUNT(user_id) AS total_users  | 	$sql = "SELECT COUNT(user_id) AS total_users  | ||||||
| 		FROM " . USERS_TABLE . "  | 		FROM " . USERS_TABLE . "  | ||||||
| 		WHERE user_id <> " . ANONYMOUS . "  | 		WHERE user_id <> " . ANONYMOUS . "  | ||||||
| 		$where_sql  | 		$where_sql"; | ||||||
| 		ORDER BY $order_by  |  | ||||||
| 		LIMIT $start, " . $board_config['topics_per_page']; |  | ||||||
| 	$result = $db->sql_query($sql); | 	$result = $db->sql_query($sql); | ||||||
|  |  | ||||||
| 	$total_users = ( $row = $db->sql_fetchrow($result) ) ? $row['total_users'] : 0; | 	$total_users = ( $row = $db->sql_fetchrow($result) ) ? $row['total_users'] : 0; | ||||||
|  |  | ||||||
| 	$pagination = generate_pagination("search.$phpEx$SID&mode=searchuser&field=$field&order=$sort_order", $total_users, $board_config['topics_per_page'], $start); | 	$pagination = generate_pagination("search.$phpEx$SID&mode=searchuser&field=$field&username=" . urlencode($username) . "&email=" . urlencode($email) . "&icq=$icq&aim=" . urlencode($aim) . "&yahoo=" . urlencode($yahoo) . "&msn=" . urlencode($msn) . "&joined=" . urlencode(implode('-', $joined)) . "&active=" . urlencode(implode('-', $active)) . "&count=$count&sort_order=$sort_order&sort_by=$sort_by&joined_select=$joined_select&active_select=$active_select&count_select=$count_select", $total_users, $board_config['topics_per_page'], $start); | ||||||
|  |  | ||||||
| 	// | 	// | ||||||
| 	// | 	// | ||||||
| @@ -1421,8 +1419,8 @@ function username_search() | |||||||
| 		'AIM' => $aim,  | 		'AIM' => $aim,  | ||||||
| 		'YAHOO' => $yahoo,  | 		'YAHOO' => $yahoo,  | ||||||
| 		'MSNM' => $msn,  | 		'MSNM' => $msn,  | ||||||
| 		'JOINED' => ( is_array($joined) ) ? implode('-', $joined) : '',  | 		'JOINED' => implode('-', $joined),  | ||||||
| 		'ACTIVE' => ( is_array($active) ) ? implode('-', $active) : '',  | 		'ACTIVE' => implode('-', $active),  | ||||||
| 		'COUNT' => $count,  | 		'COUNT' => $count,  | ||||||
|  |  | ||||||
| 		'PAGINATION' => $pagination, | 		'PAGINATION' => $pagination, | ||||||
| @@ -1448,14 +1446,14 @@ function username_search() | |||||||
| 		'L_SEARCH' => $lang['Search'],  | 		'L_SEARCH' => $lang['Search'],  | ||||||
| 		'L_CLOSE_WINDOW' => $lang['Close_window'],  | 		'L_CLOSE_WINDOW' => $lang['Close_window'],  | ||||||
|  |  | ||||||
| 		'S_FIELD_NAME' => $field_name,  | 		'S_FIELD_NAME' => $field,  | ||||||
| 		'S_COUNT_OPTIONS' => $s_find_count,  | 		'S_COUNT_OPTIONS' => $s_find_count,  | ||||||
| 		'S_JOINED_TIME_OPTIONS' => $s_find_join_time,  | 		'S_JOINED_TIME_OPTIONS' => $s_find_join_time,  | ||||||
| 		'S_ACTIVE_TIME_OPTIONS' => $s_find_active_time,  | 		'S_ACTIVE_TIME_OPTIONS' => $s_find_active_time,  | ||||||
| 		'S_SORT_OPTIONS' => $s_sort_by,  | 		'S_SORT_OPTIONS' => $s_sort_by,  | ||||||
| 		'S_SORT_ORDER' => $s_sort_order,  | 		'S_SORT_ORDER' => $s_sort_order,  | ||||||
| 		'S_USERNAME_OPTIONS' => $username_list,  | 		'S_USERNAME_OPTIONS' => $username_list,  | ||||||
| 		'S_SEARCH_ACTION' => "search.$phpEx$SID&mode=searchuser") | 		'S_SEARCH_ACTION' => "search.$phpEx$SID&mode=searchuser&field=$field") | ||||||
| 	); | 	); | ||||||
|  |  | ||||||
| 	$sql = "SELECT username, user_id, user_viewemail, user_posts, user_regdate, user_email, user_lastvisit  | 	$sql = "SELECT username, user_id, user_viewemail, user_posts, user_regdate, user_email, user_lastvisit  | ||||||
| @@ -1486,7 +1484,6 @@ function username_search() | |||||||
| 			$template->assign_block_vars('memberrow', array( | 			$template->assign_block_vars('memberrow', array( | ||||||
| 				'ROW_NUMBER' => $i + ( $start + 1 ),  | 				'ROW_NUMBER' => $i + ( $start + 1 ),  | ||||||
| 				'USERNAME' => $username, | 				'USERNAME' => $username, | ||||||
| 				'FROM' => $from, |  | ||||||
| 				'JOINED' => $joined, | 				'JOINED' => $joined, | ||||||
| 				'POSTS' => $posts,  | 				'POSTS' => $posts,  | ||||||
| 				'ACTIVE' => $active,  | 				'ACTIVE' => $active,  | ||||||
|   | |||||||
| @@ -5,12 +5,11 @@ | |||||||
| function refresh_username(selected_username) | function refresh_username(selected_username) | ||||||
| { | { | ||||||
| 	opener.document.forms[0].{S_FIELD_NAME}.value += ( opener.document.forms[0].{S_FIELD_NAME}.value.length  ) ? "\n" + selected_username : selected_username; | 	opener.document.forms[0].{S_FIELD_NAME}.value += ( opener.document.forms[0].{S_FIELD_NAME}.value.length  ) ? "\n" + selected_username : selected_username; | ||||||
| 	opener.focus(); |  | ||||||
| } | } | ||||||
| //--> | //--> | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <form method="post" name="search" action="{S_SEARCH_ACTION}"><table width="100%" cellspacing="0" cellpadding="10" border="0"> | <form method="post" name="search" action="{S_SEARCH_ACTION}"><table width="100%" cellspacing="0" cellpadding="5" border="0"> | ||||||
| 	<tr> | 	<tr> | ||||||
| 		<td><table width="100%" class="forumline" cellspacing="1" cellpadding="4" border="0"> | 		<td><table width="100%" class="forumline" cellspacing="1" cellpadding="4" border="0"> | ||||||
| 			<tr>  | 			<tr>  | ||||||
| @@ -95,22 +94,13 @@ function refresh_username(selected_username) | |||||||
| 			</tr> | 			</tr> | ||||||
| 		</table> | 		</table> | ||||||
| 		 | 		 | ||||||
| 		<table width="100%" cellspacing="0" cellpadding="0" border="0"> | 		<table width="100%" cellspacing="2" cellpadding="0" border="0"> | ||||||
| 			<tr>  | 			<tr>  | ||||||
| 				<td><span class="nav">{PAGE_NUMBER}</span></td> | 				<td valign="top"><span class="nav">{PAGE_NUMBER}</span></td> | ||||||
| 				<td align="right"><span class="gensmall">{S_TIMEZONE}</span><br /><span class="nav">{PAGINATION}</span></td> | 				<td align="right"><span class="gensmall">{S_TIMEZONE}</span><br /><span class="nav">{PAGINATION}</span></td> | ||||||
| 			</tr> | 			</tr> | ||||||
| 		</table></td> | 		</table></td> | ||||||
| 	</tr> | 	</tr> | ||||||
| </table> | </table></form> | ||||||
|  |  | ||||||
|  |  | ||||||
| <!-- IF S_SELECT_NAME --> |  | ||||||
| 	<tr> |  | ||||||
| 		<td><span class="genmed">{L_UPDATE_USERNAME}<br /><select name="username_list">{S_USERNAME_OPTIONS}</select>  <input type="submit" class="liteoption" onClick="refresh_username(this.form.username_list.options[this.form.username_list.selectedIndex].value);return false;" name="use" value="{L_SELECT}" /></span><br /><br /><span class="genmed"><a href="javascript:window.close();" class="genmed">{L_CLOSE_WINDOW}</a></span></td> |  | ||||||
| 	</tr> |  | ||||||
| <!-- ENDIF --> |  | ||||||
|  |  | ||||||
| </form> |  | ||||||
|  |  | ||||||
| <!-- INCLUDE simple_footer.html --> | <!-- INCLUDE simple_footer.html --> | ||||||
		Reference in New Issue
	
	Block a user