WooCommerce:使用变量产品

时间:2015-09-12 19:24:32

标签: php wordpress woocommerce

我正在尝试以编程方式创建订单。使用wc_create_order()这非常简单:

$myProduct = new WC_Product(100);
$order = wc_create_order();
$order->add_product($myProduct, 1);
$order->calculate_totals();

这可以按预期工作,并为ID为100的简单产品创建订单,数量正确。

但是,如果我尝试使用变体进行此操作,它似乎行为不正确。经过多次试验和错误后,我通过这种方式将 sort-of 工作了:

$membershipProduct = new WC_Product_Variable(100);
$theMemberships = $membershipProduct->get_available_variations();

$trueProduct = new WC_Product(100);

$variationsArray = array();

foreach ($theMemberships as $membership) {
    if ($membership['sku'] == $chosenVariation) {
        $variationID = $membership['variation_id'];
        $variationsArray = $membership['attributes'];
    }
}

if ($variationID) {
    $trueProduct->variation_id = $variationID;
}

$order = wc_create_order();
$order->add_product($trueProduct, 1, $variationsArray);
$order->calculate_totals();

但是,虽然它确实使用正确的产品和正确的变体ID创建了订单,但订单的总数始终为 0 (巧合的是,第一个版本的价格)。

最初我使用$order->add_product()创建的对象尝试new WC_Product_Variable(),但这导致订单中根本没有添加任何产品,这让我相信以编程方式创建订单时出现问题可变产品。但是,按照这些调用的WooCommerce源代码,我看不出我做错了什么。

是否有我缺少的东西,或者是使用可变产品创建订单的更好方法?

2 个答案:

答案 0 :(得分:0)

如果您已经拥有了variation_id,则可以执行此操作

$product_variation = new WC_Product_Variation($variation_id);
$order = wc_create_order();
$args=array();
foreach($product_variation->get_variation_attributes() as $attribute=>$attribute_value){
        $args['variation'][$attribute]=$attribute_value;
}
$order->add_product($product_variation, $product['quantity'], $args);

答案 1 :(得分:0)

以下是适合我的解决方案:

function add_item_to_order( $order_id, $prod_id ) {

    $order      = wc_get_order( $order_id );
    $_product   = wc_get_product( $prod_id ); 

    // Set values
    $item = array();
    $item['product_id']        = $_product->id;
    $item['variation_id']      = isset( $_product->variation_id ) ? $_product->variation_id : '';
    $item['variation_data']    = $item['variation_id'] ? $_product->get_variation_attributes() : '';
    $item['name']              = $_product->get_title();
    $item['tax_class']         = $_product->get_tax_class();
    $item['qty']               = 1;
    $item['line_subtotal']     = wc_format_decimal( $_product->get_price_excluding_tax() );
    $item['line_subtotal_tax'] = '';
    $item['line_total']        = wc_format_decimal( $_product->get_price_excluding_tax() );
    $item['line_tax']          = '';
    $item['type']              = 'line_item';

    // Add line item
    $item_id = wc_add_order_item( $order_id, array(
        'order_item_name'       => $item['name'],
        'order_item_type'       => 'line_item'
    ) );

    // Add line item meta
    if ( $item_id ) {
        wc_add_order_item_meta( $item_id, '_qty', $item['qty'] );
        wc_add_order_item_meta( $item_id, '_tax_class', $item['tax_class'] );
        wc_add_order_item_meta( $item_id, '_product_id', $item['product_id'] );
        wc_add_order_item_meta( $item_id, '_variation_id', $item['variation_id'] );
        wc_add_order_item_meta( $item_id, '_line_subtotal', $item['line_subtotal'] );
        wc_add_order_item_meta( $item_id, '_line_subtotal_tax', $item['line_subtotal_tax'] );
        wc_add_order_item_meta( $item_id, '_line_total', $item['line_total'] );
        wc_add_order_item_meta( $item_id, '_line_tax', $item['line_tax'] );
        wc_add_order_item_meta( $item_id, '_line_tax_data', array( 
                                                                    'total' => array(), 
                                                                    'subtotal' => array() ) 
                                                                 );
        // Store variation data in meta
        if ( $item['variation_data'] && is_array( $item['variation_data'] ) ) {
            foreach ( $item['variation_data'] as $key => $value ) {
                wc_add_order_item_meta( $item_id, str_replace( 'attribute_', '', $key ), $value );
            }
        }

    }

    $item['item_meta']       = $order->get_item_meta( $item_id );
    $item['item_meta_array'] = $order->get_item_meta_array( $item_id );
    $item                    = $order->expand_item_meta( $item );
    $order->calculate_totals();
}