InactiveSubscriber.php
1.02 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
<?php
namespace ACA\WC\Search\UserOrderSubscription;
use ACP;
use ACP\Search\Operators;
use ACP\Search\Query\Bindings;
use ACP\Search\Value;
class InactiveSubscriber extends ACP\Search\Comparison
{
public function __construct()
{
$operators = new Operators([
Operators::IS_EMPTY,
Operators::NOT_IS_EMPTY,
]);
parent::__construct($operators);
}
protected function create_query_bindings($operator, Value $value)
{
global $wpdb;
$bindings = new Bindings();
$alias_order = $bindings->get_unique_alias('orders');
$bindings->join(
"
LEFT JOIN {$wpdb->prefix}wc_orders AS $alias_order ON $wpdb->users.ID = $alias_order.customer_id
AND $alias_order.type = 'shop_subscription' AND $alias_order.status != 'wc-active'
"
);
$compare = $operator === Operators::IS_EMPTY ? 'IS NULL' : 'IS NOT NULL';
$bindings->where("$alias_order.id $compare");
return $bindings;
}
}