如何解决我如何在woocommerce上有超过一种缺货类型?
我正在使用“ How to add new stock status to products in WooCommerce”更改我代表客户制作的课程网站在WooCommerce上的可用性文本。
// Availability text
function filter_woocommerce_get_availability_text( $availability,$product ) {
switch( $product->stock_status ) {
case 'coming_soon':
$availability = __( 'Coming soon','woocommerce' );
break;
case 'dtbc':
$availability = __( 'Dates to be confirmed','woocommerce' );
break;
}
return $availability;
}
add_filter( 'woocommerce_get_availability_text','filter_woocommerce_get_availability_text',10,2 );
// Availability class
function filter_woocommerce_get_availability_class( $class,$product ) {
switch( $product->stock_status ) {
case 'coming_soon':
$class = 'coming_soon';
break;
case 'dtbc':
$class = 'dtbc';
break;
}
return $class;
}
add_filter( 'woocommerce_get_availability_class','filter_woocommerce_get_availability_class',2 );
我正在寻找帮助,以关闭我添加的两个额外类的购买能力,从而使它们实际上是缺货的不同变体。任何帮助将不胜感激。
解决方法
例如,我创建了一个名为“售罄”的新状态, 当 is_in_stock 函数被调用时,返回 false。
// Add new stock status options
function filter_woocommerce_product_stock_status_options( $status ) {
// Add new statuses
$status['sold'] = 'Sold Out';
return $status;
}
add_filter( 'woocommerce_product_stock_status_options','filter_woocommerce_product_stock_status_options',10,1 );
function filter_woocommerce_get_availability_text( $availability,$product ) {
// Get stock status
switch( $product->get_stock_status() ) {
case 'sold':
$availability = 'Sold Out';
break;
}
return $availability;
}
add_filter( 'woocommerce_get_availability_text','filter_woocommerce_get_availability_text',2 );
// Availability CSS class
function filter_woocommerce_get_availability_class( $class,$product ) {
// Get stock status
switch( $product->get_stock_status() ) {
case 'sold':
$class = 'sold';
break;
}
return $class;
}
add_filter( 'woocommerce_get_availability_class','filter_woocommerce_get_availability_class',2 );
// Set is_in_stock For Sold status
function filter_woocommerce_product_is_in_stock( $instock_this_get_stock_status,$instance ) {
if($instance->stock_status == 'sold'){
return false;
}
}
add_filter( 'woocommerce_product_is_in_stock','filter_woocommerce_product_is_in_stock',2 );