将所有特定订单商品自定义字段的总和保存为WooCommerce中的订单元数据

问题描述 投票:2回答:1

在我之前的问题“Save WooCommerce order item custom fields sum as a new meta data”之后,当下订单时,保存了一些订单项自定义元数据quantityassemblycostcalculated_field(其值为quantity x assemblycost)。

如何将自定义订单元数据保存为所有订单商品calculated_field值的总和?

例如,样本订单看起来如下:

Product A:
assemblycost: 10
quantity: 2
calculated_field: 20

Product B:
assemblycost: 15
quantity: 2
calculated_field: 30

Product C: 
no assemblycost, quanity or calculated_field - custom fields present. 

Product D: 
assemblycost: 30
quantity: 2
calculated_field: 60

我想为sum_calculated_fields订单创建一个新的自定义字段,并将其设置为顺序中calculated_fields的总和,因此在上面的示例中它将等于:

20+30+60 = 110.

php wordpress woocommerce hook-woocommerce orders
1个回答
3
投票

更新:以下是对所有订单商品calculated_fields自定义字段求和的方法,并将该总和保存为自定义订单元数据:

add_action( 'woocommerce_checkout_create_order', 'action_checkout_create_order_callback', 10, 2 );
function action_checkout_create_order_callback( $order, $data ) {
    $calculated_fields_sum = 0; // Initializing

    // Loop Through order items
    foreach ( $order->get_items() as $item ) {
        if( $value = $item->get_meta('calculated_field') ) {
            $calculated_fields_sum += $value;
        }
    }
    // Update order meta data
    if( $calculated_fields_sum > 0 ) {
        $order->update_meta_data( 'calculated_fields_sum', $calculated_fields_sum );
    }
}

代码位于活动子主题(或活动主题)的function.php文件中。它应该工作。

© www.soinside.com 2019 - 2024. All rights reserved.