php - WooCommerce - 自定义库存状态和可变产品
问题描述
在我们的网站上,我们正在为我们的产品使用自定义库存状态。我们使用下面的代码来实现这一点,它可以工作,但是变量产品存在一些问题,它会变回默认状态。
我们想在可变产品上使用它,以显示整个产品的主要库存状态,但是当我们选择自定义库存状态时,它会在一段时间后突然变回标准库存状态。当我们更新产品时它会保存设置,但它最终会在一段时间后将其更改回来。
这是我们的代码,它放在我们的functions.php文件中。希望你能帮助或指出我正确的方向:
function add_custom_stock_type() {
?>
<script type="text/javascript">
jQuery(function(){
jQuery('._stock_status_field').not('.custom-stock-status').remove();
});
</script>
<?php
woocommerce_wp_select( array( 'id' => '_stock_status', 'wrapper_class' => 'custom-stock-status', 'label' => __( 'Stock status', 'woocommerce' ), 'options' => array(
'instock' => __( 'På lager/fjernlager', 'woocommerce' ),
'bestillingsvare' => __( 'Bestillingsvare', 'woocommerce' ), // The new option !!!
'outofstock' => __( 'Ikke på lager', 'woocommerce' ),
), 'desc_tip' => true, 'description' => __( 'Controls whether or not the product is listed as "in stock" or "out of stock" on the frontend.', 'woocommerce' ) ) );
}
add_action('woocommerce_product_options_stock_status', 'add_custom_stock_type');
function save_custom_stock_status( $product_id ) {
update_post_meta( $product_id, '_stock_status', wc_clean( $_POST['_stock_status'] ) );
}
add_action('woocommerce_process_product_meta', 'save_custom_stock_status',99,1);
function woo_add_custom_general_fields_save_two( $post_id ){
// Select
$woocommerce_select = $_POST['_stock_status'];
if( !empty( $woocommerce_select ) )
update_post_meta( $post_id, '_stock_status', esc_attr( $woocommerce_select ) );
else
update_post_meta( $post_id, '_stock_status', '' );
}
function woocommerce_get_custom_availability( $data, $product ) {
switch( $product->stock_status ) {
case 'instock':
$data = array( 'availability' => __( 'På lager/fjernlager', 'woocommerce' ), 'class' => 'in-stock' );
break;
case 'bestillingsvare':
$data = array( 'availability' => __( 'Bestillingsvare', 'woocommerce' ), 'class' => 'bestillings-vare' );
break;
case 'outofstock':
$data = array( 'availability' => __( 'Ikke på lager', 'woocommerce' ), 'class' => 'out-of-stock' );
break;
}
return $data;
}
add_action('woocommerce_get_availability', 'woocommerce_get_custom_availability', 10, 2);
解决方案
2019 年更新:
2019 年 2 月,WooCommerce 在3.6.0 版本中添加了一个过滤器,允许用户添加自己的自定义库存状态。
在定义不同库存状态的函数内部wc_get_product_stock_status_options
,有 3 个默认的内置状态:instock
、outofstock
和onbackorder
。
为了添加自定义状态或删除内置状态,您可以简单地使用新woocommerce_product_stock_status_options
过滤器:
add_filter('woocommerce_product_stock_status_options', 'add_custom_stock_statuses');
function add_custom_stock_statuses($statuses) {
// Add a new status
$statuses['customstatus'] = __( 'My Custom Status', 'plugin-name' );
// Remove a built-in status
unset($statuses['onbackorder']);
return $statuses;
}
推荐阅读
- reactjs - 如何解决文本输入中的文本光标在插入键入的字符后自动放置在输入末尾的问题?
- azure - Azure VM -> 灾难恢复选项卡 -> 显示错误页面
- java - 使用mybatis executortype.batch时如何查找错误的参数一次插入批处理
- json - 从数据库导出到 JSON 文件
- javascript - 如何通过 JavaScript 从包含通过术语库存储值的列的 SharePoint 列表中获取值?
- reactjs - 盖茨比插件图像 |
不显示图像 - python - 将 JSON 数组提取到数据框列中
- qt - 通过 cmake 将 glfw 添加到 Qt
- python - 莳萝加载不返回相同的转储函数
- datatables - 在 dataTable 的自定义选择框中传递数据