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
|
<?php // phpcs:ignoreFile
namespace AutomateWoo\Rules;
use AutomateWoo\DataTypes\DataTypes; use AutomateWoo\RuleQuickFilters\Clauses\ClauseInterface; use AutomateWoo\RuleQuickFilters\Clauses\NoOpClause; use AutomateWoo\Rules\Interfaces\NonPrimaryDataTypeQuickFilterable; use AutomateWoo\Rules\Utilities\DataTypeConditions; use AutomateWoo\Rules\Utilities\StringQuickFilter; use Exception;
defined( 'ABSPATH' ) || exit;
/** * @class Customer_Postcode */ class Customer_Postcode extends Abstract_String implements NonPrimaryDataTypeQuickFilterable {
use StringQuickFilter; use DataTypeConditions;
public $data_item = DataTypes::CUSTOMER;
function init() { $this->title = __( 'Customer - Postcode', 'automatewoo' ); }
/** * @param $customer \AutomateWoo\Customer * @param $compare * @param $value * @return bool */ function validate( $customer, $compare, $value ) { return $this->validate_string( $this->data_layer()->get_customer_postcode(), $compare, $value ); }
/** * Get any non-primary data type quick filter clauses for this rule. * * @since 5.0.0 * * @param string $data_type The data type that is being filtered. * @param string $compare_type The rule's compare type. * @param mixed $value The rule's expected value. * * @return ClauseInterface * * @throws Exception When there is an error. */ public function get_non_primary_quick_filter_clause( $data_type, $compare_type, $value ) { // Return clauses for order and subscription queries if ( $this->is_data_type_order_or_subscription( $data_type ) ) { return $this->generate_string_quick_filter_clause( 'billing_postcode', $compare_type, $value ); }
return new NoOpClause(); }
}
|