/var/www/html_uk/wp-content/plugins/automatewoo/includes/Actions/Subscription_Add_Coupon.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
<?php

namespace AutomateWoo;

if ( ! 
defined'ABSPATH' ) ) {
    exit;
}

/**
 * Action to add a chosen coupon code to a subscription.
 *
 * @class Action_Subscription_Add_Coupon
 * @since 4.4
 */
class Action_Subscription_Add_Coupon extends Action_Subscription_Edit_Coupon_Abstract {

    
/**
     * Class constructor
     */
    
public function __construct() {
        
// Only recurring coupons can be added to subscriptions.
        
$this->set_recurring_coupon_onlytrue );
    }

    
/**
     * Explain to store admin what this action does via a unique title and description.
     */
    
public function load_admin_details() {
        
parent::load_admin_details();
        
$this->title       __'Add Coupon''automatewoo' );
        
$this->description __'Add a coupon to discount future payments for a subscription. The coupon will be added using the discount amount set on the coupon. This action can be used for bulk editing subscriptions, or to change the coupons provided to a subscriber at different stages of their subscription\'s lifecycle. The same coupon code will only be added once to a subscription. Only recurring coupon types can be added.''automatewoo' );
    }


    
/**
     * Add a given coupon as a line item to a given subscription.
     *
     * @param \WC_Coupon       $coupon Coupon to add to the subscription.
     * @param \WC_Subscription $subscription Instance of subscription to add the coupon to.
     *
     * @throws \Exception When there is an error.
     *
     * @return bool True if the subscription was edited, false if no change was made.
     */
    
protected function edit_subscription$coupon$subscription ) {
        
$response $subscription->apply_coupon$coupon );

        if ( 
is_wp_error$response ) ) {
            throw new 
\Exceptionesc_html$response->get_error_message() ) );
        }

        return 
true;
    }


    
/**
     * Get a message to add to the subscription to record the coupon being added by this action.
     *
     * Helpful for tracing the history of this action by viewing the subscription's notes.
     *
     * @param \WC_Coupon $coupon Coupon being added to the subscription. Required so its name can be added to the order note.
     * @return string
     */
    
protected function get_note$coupon ) {
        
/* translators: %1$s: workflow title, %2$s coupon code, %3$d workflow ID */
        
return sprintf__'%1$s workflow run: added coupon %2$s to subscription. (Workflow ID: %3$d)''automatewoo' ), $this->workflow->get_title(), $coupon->get_code(), $this->workflow->get_id() );
    }
}