/var/www/html_uk/wp-content/plugins/automatewoo/includes/Rules/Order_Created_Date.php


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;

/**
 * Order date rule.
 *
 * @class Order_Created_Date
 */
class Order_Created_Date extends Abstract_Date implements QuickFilterable {

    use 
DateQuickFilter;

    
/**
     * Data item type.
     *
     * @var string
     */
    
public $data_item 'order';

    
/**
     * Order_Created_Date constructor.
     */
    
public function __construct() {
        
$this->has_is_past_comparision true;

        
parent::__construct();
    }

    
/**
     * Init
     */
    
public function init() {
        
$this->title __'Order - Created Date''automatewoo' );
    }


    
/**
     * Validates rule.
     *
     * @param \WC_Order  $order   Order we're validating against.
     * @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$order$compare$value null ) {
        return 
$this->validate_date$compare$valueaw_normalize_date$order->get_date_created() ) );
    }

    
/**
     * Get quick filter clause.
     *
     * @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 );
    }
}