Groups.php
1.54 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<?php
namespace ACA\BP\Search\User;
use AC;
use ACA\BP\Helper\Select;
use ACA\BP\Helper\Select\Formatter;
use ACP\Search\Comparison;
use ACP\Search\Operators;
use ACP\Search\Query\Bindings;
use ACP\Search\Value;
class Groups extends Comparison
implements Comparison\SearchableValues {
public function __construct() {
$operators = new Operators( [
Operators::EQ,
Operators::IS_EMPTY,
Operators::NOT_IS_EMPTY,
] );
parent::__construct( $operators );
}
/**
* @inheritDoc
*/
protected function create_query_bindings( $operator, Value $value ) {
global $wpdb, $bp;
$bindings = new Bindings();
switch ( $operator ) {
case Operators::EQ:
$bindings->join( $wpdb->prepare( "
INNER JOIN {$bp->groups->table_name_members} AS bptm ON {$wpdb->users}.ID = bptm.user_id
AND bptm.group_id = %d AND bptm.is_banned = 0
", (int) $value->get_value() ) );
break;
case Operators::IS_EMPTY:
$bindings->where( "NOT EXISTS( SELECT user_id FROM {$bp->groups->table_name_members} WHERE user_id = {$wpdb->users}.ID )" );
break;
case Operators::NOT_IS_EMPTY:
$bindings->join( "INNER JOIN {$bp->groups->table_name_members} AS bptm ON {$wpdb->users}.ID = bptm.user_id AND is_confirmed = 1 AND is_banned = 0" );
break;
}
return $bindings;
}
public function get_values( $search, $page ) {
$entities = new Select\Entities\Group( [
'search_terms' => $search,
'page' => $page,
] );
return new AC\Helper\Select\Options\Paginated(
$entities,
new Formatter\Group( $entities )
);
}
}