Php 在WooCommerce中添加自定义库存状态
我想在产品的股票期权下拉列表中添加一个新的期权。默认情况下,有“缺货”、“库存”,我想添加第三个选项 我找到了显示下拉列表的方法(在class-wc-meta-box-product-data.php中)Php 在WooCommerce中添加自定义库存状态,php,wordpress,coding-style,woocommerce,Php,Wordpress,Coding Style,Woocommerce,我想在产品的股票期权下拉列表中添加一个新的期权。默认情况下,有“缺货”、“库存”,我想添加第三个选项 我找到了显示下拉列表的方法(在class-wc-meta-box-product-data.php中) 但我不想直接编辑Woocommerce类,这样我们就可以在不丢失任何自定义代码的情况下更新Woocommerce。有没有办法覆盖这个方法 我最后用Javascript隐藏了以前的股票期权下拉列表 add_action('woocommerce_product_options_stock_sta
但我不想直接编辑Woocommerce类,这样我们就可以在不丢失任何自定义代码的情况下更新Woocommerce。有没有办法覆盖这个方法 我最后用Javascript隐藏了以前的股票期权下拉列表
add_action('woocommerce_product_options_stock_status', 'add_custom_stock_type');
function add_custom_stock_type() {
// Stock status - We remove the default one
?>
<script type="text/javascript">
jQuery('_stock_status').remove();
</script>
<?php
}
add_action('woocommerce_product_options_stock_status'、'add_custom_stock_type');
函数add_custom_stock_type(){
//库存状态-我们删除默认状态
?>
jQuery(“U库存状态”).remove();
对于任何感兴趣的人,这里有一个基于Laila方法的完整解决方案。警告!我的解决方案仅适用于WooCommerce禁用“管理股票”选项的情况。!我不处理确切数量的股票。所有代码都会像往常一样转到functions.php
后端部件
删除本机股票状态下拉列表字段。添加CSS类以区分我的新自定义字段。下拉列表现在有新选项“按请求”
模板部件
最后一件事-我必须更改产品get_availability()
函数返回的数据。当“管理库存”关闭时,WooCommerce再次只知道“库存增加”和“库存减少”值。因此我必须自己检查库存状态
function woocommerce_get_custom_availability( $data, $product ) {
switch( $product->stock_status ) {
case 'instock':
$data = array( 'availability' => __( 'In stock', 'woocommerce' ), 'class' => 'in-stock' );
break;
case 'outofstock':
$data = array( 'availability' => __( 'Out of stock', 'woocommerce' ), 'class' => 'out-of-stock' );
break;
case 'onrequest':
$data = array( 'availability' => __( 'On request', 'woocommerce' ), 'class' => 'on-request' );
break;
}
return $data;
}
add_action('woocommerce_get_availability', 'woocommerce_get_custom_availability', 10, 2);
也许这不是防弹解决方案…我最终会更新它。对不起,如果不更改核心文件,您要查找的内容是不可能的,这些更改将在升级时丢失。我已经看到了此链接,但我想知道是否有其他解决方案。您可以在下面查看我自己的答案。这对我有用,谢谢。Got有库存、无库存、1-3天和3-5天的期权。看起来像是添加操作(“woocommerce\u get\u availability”,“woocommerce\u get\u custom\u availability”,10,2);应该是一个添加过滤器来完成这项工作。不,添加操作
和添加过滤器
是相同的功能。请参阅。但是,为了更好地理解,应该是添加过滤器。
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' => 'hide_if_variable custom-stock-status', 'label' => __( 'Stock status', 'woocommerce' ), 'options' => array(
'instock' => __( 'In stock', 'woocommerce' ),
'outofstock' => __( 'Out of stock', 'woocommerce' ),
'onrequest' => __( 'On Request', 'woocommerce' ), // The new option !!!
), '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 woocommerce_get_custom_availability( $data, $product ) {
switch( $product->stock_status ) {
case 'instock':
$data = array( 'availability' => __( 'In stock', 'woocommerce' ), 'class' => 'in-stock' );
break;
case 'outofstock':
$data = array( 'availability' => __( 'Out of stock', 'woocommerce' ), 'class' => 'out-of-stock' );
break;
case 'onrequest':
$data = array( 'availability' => __( 'On request', 'woocommerce' ), 'class' => 'on-request' );
break;
}
return $data;
}
add_action('woocommerce_get_availability', 'woocommerce_get_custom_availability', 10, 2);