我在WooCommerce应用程序中创建了自定义产品类型
function register_variable_bulk_product_type() {
class WC_Product_Variable_bulk extends WC_Product_Simple {
public function __construct($product) {
$this->product_type = 'variable_bulk';
parent::__construct($product);
}
}
}
add_action('init', 'register_variable_bulk_product_type');
function add_variable_bulk_product($types) {
$types['variable_bulk'] = __('Variable Bulk');
return $types;
}
add_filter('product_type_selector', 'add_variable_bulk_product');
这会在产品数据下拉列表中显示产品类型,如下所示,
我的问题是
新产品没有添加库存和价格的选项,如何启用这些选项?
解决方法:
You need a small JS trick to show Price and Inventory tab, i.e. you
need to add classshow_if_{your_custom_product_type}
in your case it
will beshow_if_variable_bulk
.
这是工作代码:
function wh_variable_bulk_admin_custom_js() {
if ('product' != get_post_type()) :
return;
endif;
?>
<script type='text/javascript'>
jQuery(document).ready(function () {
//for Price tab
jQuery('.product_data_tabs .general_tab').addClass('show_if_variable_bulk').show();
jQuery('#general_product_data .pricing').addClass('show_if_variable_bulk').show();
//for Inventory tab
jQuery('.inventory_options').addClass('show_if_variable_bulk').show();
jQuery('#inventory_product_data ._manage_stock_field').addClass('show_if_variable_bulk').show();
jQuery('#inventory_product_data ._sold_individually_field').parent().addClass('show_if_variable_bulk').show();
jQuery('#inventory_product_data ._sold_individually_field').addClass('show_if_variable_bulk').show();
});
</script>
<?php
}
add_action('admin_footer', 'wh_variable_bulk_admin_custom_js');
代码进入您的活动子主题(或主题)的functions.php文件中.或也在任何插件PHP文件中.
代码已经过测试并且可以正常工作.
这是您的常规标签的外观:
这是库存标签的外观
希望这可以帮助!