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

namespace AutomateWoo\Actions\Subscriptions;

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

/**
 * Action to update a shipping method from a subscription.
 *
 * @since 5.4.0
 */
class UpdateShipping extends AddShipping {


    
/**
     * 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       __'Update Shipping''automatewoo' );
        
$this->description __'Update a shipping line item or items from a subscription, if any line items match the chosen shipping method. This is useful for bulk editing subscriptions, or to change the shipping charged to a subscriber at different stages of their subscription\'s lifecycle. Please note: all line items for the chosen shipping method will be updated.''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 ) {

        
$shipping_line_item null;

        foreach ( 
$subscription->get_shipping_methods() as $line_item ) {
            
// Same approach used in Abstract_WC_Order::has_shipping_method() to check for method
            
if ( === strpos$line_item->get_method_id(), $shipping_data['shipping_method_id'] ) ) {
                
$shipping_line_item $line_item;
                break;
            }
        }

        
// No item for that shipping method on this subscription
        
if ( empty( $shipping_line_item ) ) {
            return 
false;
        }

        
$update_args = [];

        if ( 
$this->get_option'line_item_name' ) ) {
            
$update_args['name'] = $this->get_option'line_item_name'true );
        }

        if ( 
$this->get_option'line_item_cost' ) ) {
            
$update_args['total'] = $this->get_option'line_item_cost'true );
        }

        if ( ! empty( 
$update_args ) ) {
            
$shipping_line_item->set_props$update_args );
            
$shipping_line_item->save();
        }

        
// Now we need to refresh the subscription to make sure it has the up-to-date line item then recalculate its totals so taxes etc. are updated
        
$subscription wcs_get_subscription$subscription->get_id() );
        
$subscription->calculate_totals();

        return 
true;
    }


    
/**
     * Create a note recording the shipping method ID and workflow name to add after updating shipping.
     *
     * 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$d shipping method ID, %3$d workflow ID */
        
return sprintf__'%1$s workflow run: updated shipping on subscription. (Shipping Method ID: %2$d; Workflow ID: %3$d)''automatewoo' ), $this->workflow->get_title(), $shipping_data['shipping_method_id'], $this->workflow->get_id() );
    }
}