遵循我上一个的问题"将WooCommerce订单项自定义字段的总和保存为新的元数据">,下订单时,保存一些订单项自定义元数据quantity
、assemblycost
和calculated_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活动子主题(或活动主题(的文件。它应该有效。