【问题标题】:Save the sum of all specific order item custom fields as order meta data in WooCommerce将所有特定订单项目自定义字段的总和保存为 WooCommerce 中的订单元数据
【发布时间】:2019-09-16 15:31:39
【问题描述】:

按照我之前的问题 " Save WooCommerce order item custom fields sum as a new meta data",下单时,一些订单项自定义元数据quantityassemblycostcalculated_field(哪个值是quantityxassemblycost em> 已保存。

如何将所有订单项目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 woocommerce metadata hook-woocommerce orders


【解决方案1】:

更新:这是对所有订单项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 文件中。它应该可以工作。

【讨论】:

    猜你喜欢
    • 2023-03-15
    • 2019-09-16
    • 2021-05-17
    • 1970-01-01
    • 1970-01-01
    • 2019-06-21
    • 2018-07-04
    • 1970-01-01
    • 2021-05-12
    相关资源
    最近更新 更多