得到库存中的"" Woocommerce

时间:2018-02-09 16:55:29

标签: php wordpress woocommerce stock variations

我试图为functions.php文件制作一个代码段,只显示所选变体的一个价格,从而忽略单个产品页面上显示的价格范围以及变化价格。我使用以下代码:

    add_action( 'woocommerce_before_single_product', 'my_remove_variation_price' );
$product_variations=$product_variable->get_available_variations;
function my_remove_variation_price() {
  global $product;
  if ( $product->is_type( 'variable' ) {
    remove_action( 'woocommerce_single_product_summary', 'woocommerce_template_single_price' );
  }
}

问题在于,例如,当您有两种不同的单品和一种缺货时,此脚本会隐藏单个产品页面上剩余的一个变体的价格。 我想也许每个产品可以有COUNT个可用的变体,并使用IF来使用标准的单个产品模板显示它们。或者你可能更清楚如何解决这个问题?

2 个答案:

答案 0 :(得分:2)

获得"库存"您可以在单个产品页面上更改可变产品的数量:

1)仅使用php和Woocommerce WC_Product方法:

global $product;
$count_in_stock = 0;

if ( $product->is_type( 'variable' ) ) {
    $variation_ids = $product->get_children(); // Get product variation IDs

    foreach( $variation_ids as $variation_id ){
        $variation = wc_get_product($variation_id);
        if( $variation->is_in_stock() )
            $count_in_stock++;
    }
}

// Your condition
if( $count_in_stock <= 1 ){
   // Do something
}

2)使用几乎没有php(快速和轻量级)的SQL查询:

global $wpdb, $product;
$product_id = $product->get_id();
$count_in_stock = 0;

if ( $product->is_type( 'variable' ) ) {
    $count = $wpdb->get_col("
        SELECT count(p.ID) as in_stock_count FROM {$wpdb->prefix}postmeta as pm
        INNER JOIN {$wpdb->prefix}posts as p ON pm.post_id = p.ID
        WHERE p.post_type LIKE 'product_variation' AND p.post_parent = $product_id
        AND pm.meta_key LIKE '_stock_status' AND pm.meta_value LIKE 'instock'
    ");

    $count_in_stock = reset($count);
}

// Your condition
if( $count_in_stock <= 1 ){
   // Do something
}      

这两个代码都经过测试和工作。

答案 1 :(得分:1)

这是我的最终工作代码,在LoicTheAztec答案的帮助下实现:

add_action( 'woocommerce_before_single_product', 'my_remove_variation_price' );
function my_remove_variation_price() {
    global $product;
    $count_in_stock = 0;

    if ( $product->is_type( 'variable' )) {

        $variation_ids = $product->get_children(); // Get product variation IDs

        foreach( $variation_ids as $variation_id ){
            $variation = wc_get_product($variation_id);
            if( $variation->is_in_stock() )
                $count_in_stock++;
        }   
    }

    if( $count_in_stock <= 1 ) 
    {
        remove_action( 'woocommerce_single_product_summary', 'woocommerce_template_single_price' );
    }   

}