在我之前的问题“Save WooCommerce order item custom fields sum as a new meta data”之后,当下订单时,保存了一些订单项自定义元数据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 );
}
}
代码位于活动子主题(或活动主题)的function.php文件中。它应该工作。