在Woocommerce中自动完成订单流程中排除特定产品

时间:2018-08-13 07:03:28

标签: types woocommerce product orders payment-method

我目前正在使用代码from this answer thread自动完成订单,以便将新的WooCommerce预订添加到日历中(它们只有在标记为完成后才会添加)。

这非常适合预订,但是,我想从自动填充中排除其他一些产品。

你知道这是否可能吗?

1 个答案:

答案 0 :(得分:1)

遍历订单项是一个繁重的过程,而不是进行更轻松的SQL查询。

这是一个自定义条件函数,它将检查Woocommerce订单中的产品ID(返回true或false):

function order_has_products( $order_id, $product_ids ){
    $product_ids = implode( "','", $product_ids );
    global $wpdb;
    $result = $wpdb->get_var( "
        SELECT COUNT(woim.meta_value) FROM {$wpdb->prefix}woocommerce_order_itemmeta as woim
        INNER JOIN {$wpdb->prefix}woocommerce_order_items as woi ON woi.order_item_id = woim.order_item_id
        WHERE woi.order_id = $order_id AND woim.meta_key IN ('_product_id','_variation_id')
        AND woim.meta_value IN ('$product_ids')
    " );
    return $result > 0 ? true : false;
}

然后您将以这种方式使用它:

add_action('woocommerce_thankyou', 'wc_auto_complete_order', 20, 1);
function wc_auto_complete_order($order_id){
    if (!$order_id)  return;

    // HERE define your Product Ids to exclude in the array 
    $product_ids = array( 37, 53 );

    // Get an instance of the WC_Product object
    $order = wc_get_order($order_id);

    $found  = order_has_products( $order_id, $product_ids );

    if ( in_array( $order->get_payment_method(), array('cod', 'cheque', '') ) || $found ) {
        return;
    }
    else {
        $order->update_status('completed');
    }

}

代码进入您的活动子主题(或活动主题)的function.php文件中。经过测试,可以正常工作。


WooCommerce: Auto complete paid Orders (depending on Payment methods)