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
68
69
70
71
72
73
|
<?php
namespace AutomateWoo\Rules;
use AutomateWoo\RuleQuickFilters\Clauses\ClauseInterface; use AutomateWoo\Rules\Interfaces\QuickFilterable; use AutomateWoo\Rules\Utilities\DateQuickFilter; use Exception;
defined( 'ABSPATH' ) || exit;
/** * Subscription created date rule. * * @Class Subscription_Created_Date * @package AutomateWoo\Rules */ class Subscription_Created_Date extends Abstract_Date implements QuickFilterable {
use DateQuickFilter;
/** * Data item type. * * @var string */ public $data_item = 'subscription';
/** * Subscription_Created_Date constructor. */ public function __construct() { $this->has_is_past_comparision = true;
parent::__construct(); }
/** * Init. */ public function init() { $this->title = __( 'Subscription - Created Date', 'automatewoo' ); }
/** * Validates rule. * * @param \WC_Subscription $subscription The subscription. * @param string $compare What variables we're using to compare. * @param array|null $value The values we have to compare. Null is only allowed when $compare is is_not_set. * * @return bool */ public function validate( $subscription, $compare, $value = null ) { return $this->validate_date( $compare, $value, aw_normalize_date( $subscription->get_date_created() ) ); }
/** * Get quick filter clause for this rule. * * @since 5.0.0 * * @param string $compare_type * @param mixed $value * * @return ClauseInterface * * @throws Exception When there is an error. */ public function get_quick_filter_clause( $compare_type, $value ) { return $this->generate_date_quick_filter_clause( 'date_created', $compare_type, $value ); } }
|