/var/www/html_uk/wp-content/plugins/automatewoo/includes/Actions/Subscriptions/AddShipping.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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
<?php

namespace AutomateWoo\Actions\Subscriptions;

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

/**
 * Action to add a chosen shipping line item to a subscription with a chosen cost.
 *
 * @since 5.4.0
 */
class AddShipping extends AbstractEditShipping {


    
/**
     * Overload parent::$requires_quantity_field to prevent the quantity field being added by
     * parent::load_fields(), as it is not used for shipping removal.
     *
     * @var bool
     */
    
protected $load_quantity_field false;


    
/**
     * Flag to define whether the instance of this action requires a name text input field.
     *
     * @var bool
     */
    
protected $load_name_field true;


    
/**
     * Flag to define whether the instance of this action requires a price input field to
     * be displayed on the action's admin UI.
     *
     * @var bool
     */
    
protected $load_cost_field true;


    
/**
     * 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 Shipping''automatewoo' );
        
$this->description __'Add shipping as a new line item on a subscription. This action can be used to change the shipping and other line items charged to a subscriber at different stages of their subscription\'s lifecycle.''automatewoo' );
    }


    
/**
     * Add a given shipping as a line item to a given subscription.
     *
     * @param array            $shipping_data Shipping line item data. Same data as the return value of @see $this->get_object_for_edit().
     * @param \WC_Subscription $subscription Instance of subscription to add the shipping to.
     *
     * @return bool True if the subscription was edited, false if no change was made.
     */
    
protected function edit_subscription$shipping_data$subscription ) {

        
$rate = new \WC_Shipping_Rate$shipping_data['shipping_method_id'], $shipping_data['line_item_name'], $shipping_data['line_item_cost'], [], $shipping_data['shipping_method_id'] );
        
$item = new \WC_Order_Item_Shipping();
        
$item->set_props(
            [
                
'method_title' => $rate->label,
                
'method_id'    => $rate->id,
                
'total'        => wc_format_decimal$rate->cost ),
                
'taxes'        => $rate->taxes,
            ]
        );
        foreach ( 
$rate->get_meta_data() as $key => $value ) {
            
$item->add_meta_data$key$valuetrue );
        }
        
$subscription->add_item$item );
        
$subscription->save();
        
$subscription->calculate_totals();

        return 
true;
    }


    
/**
     * Get a message to add to the subscription to record the shipping being added by this action.
     *
     * Helpful for tracing the history of this action by viewing the subscription's notes.
     *
     * @param array $shipping_data Shipping line item data. Same data as the return value of @see $this->get_object_for_edit().
     * @return string
     */
    
protected function get_note$shipping_data ) {
        
/* translators: %1$s: workflow title, %2$s line item name, %3$d shipping method ID, %4$d workflow ID */
        
return sprintf__'%1$s workflow run: added %2$s to subscription. (Shipping Method ID: %3$d; Workflow ID: %4$d)''automatewoo' ), $this->workflow->get_title(), $shipping_data['line_item_name'], $shipping_data['shipping_method_id'], $this->workflow->get_id() );
    }
}