Try:
class BP_Custom_User_Ids {
private $custom_ids = array();
public function __construct() {
$this->custom_ids = $this->get_custom_ids();
add_action( 'bp_pre_user_query_construct', array( $this, 'custom_members_query' ), 1, 1 );
add_filter( 'bp_get_total_member_count', array( $this, 'custom_members_count' ), 1, 1 );
}
private function get_custom_ids() {
global $wpdb;
//figure out if the logged-in user is engineer or it
$s = xprofile_get_field_data( 2, bp_loggedin_user_id() );
if( is_super_admin() ) {
$custom_ids = false;
}
elseif ( $s == 'IT/ISM' ) {
$query = "SELECT user_id FROM {$wpdb->prefix}bp_xprofile_data WHERE field_id = 2 AND value="IT/ISM"";
$custom_ids = $wpdb->get_col( $query );
}
elseif ( $s == 'Engineering' ) {
$query = "SELECT user_id FROM {$wpdb->prefix}bp_xprofile_data WHERE field_id = 2 AND value="Engineering"";
$custom_ids = $wpdb->get_col( $query );
}
else {
$custom_ids = false;
}
return $custom_ids;
}
function custom_members_query( $query_array ) {
$query_array->query_vars['include'] = $this->custom_ids;
}
function custom_members_count ( $count ) {
if( $this->custom_ids == false )
return $count;
else {
$new_count = count( $this->custom_ids );
return $new_count;
}
}
}