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



遵循我上一个的问题"将WooCommerce订单项自定义字段的总和保存为新的元数据">,下订单时,保存一些订单项自定义元数据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。

更新:以下是将所有订单项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 );
    }
}

代码进入函数.php活动子主题(或活动主题(的文件。它应该有效。

相关内容

  • 没有找到相关文章

最新更新