嗯,这比我想象的要棘手得多。该解决方案分为三个部分。
首先,您必须向管理产品元框添加一个复选框。我认为如果我们将其放置在库存状态输入附近会比较合适。
add_action( 'woocommerce_product_options_stock_status', 'so_27971630_hide_if_out_of_stock' );
function so_27971630_hide_if_out_of_stock(){
woocommerce_wp_checkbox( array( 'id' => '_hide_if_out_of_stock', 'wrapper_class' => 'show_if_simple show_if_variable', 'label' => __( 'Hide this product from archives when out of stock?', 'your-plugin-domain' ) ) );
}
然后我们需要保存这些数据。通常,我会将复选框保存为“是”与“否”,就像 WooCommerce 那样。但是,要使产品查询正确,要求当您想要隐藏该项目时元存在,否则根本不存在......因此 if/elseupdate_post_meta()
versus delete_post_meta()
add_action( 'woocommerce_process_product_meta', 'so_27971630_save_product_meta' );
function so_27971630_save_product_meta( $post_id ){
if( isset( $_POST['_hide_if_out_of_stock'] ) ) {
update_post_meta( $post_id, '_hide_if_out_of_stock', 'yes' );
} else {
delete_post_meta( $post_id, '_hide_if_out_of_stock' );
}
}
最后,我们需要调整产品查询。 WooCommerce 为其产品构建自定义查询WC_Query
班级。基本上我所做的是,如果您没有通过插件选项大规模隐藏所有缺货商品,此代码将修改元查询,以便任何没有元键的商品_hide_if_out_of_stock
将显示。这是一种反直觉的说法,即任何选中“缺货时隐藏”框的产品都将被隐藏。
add_action( 'woocommerce_product_query', 'so_27971630_product_query' );
function so_27971630_product_query( $q ){
$meta_query = $q->get( 'meta_query' );
if ( get_option( 'woocommerce_hide_out_of_stock_items' ) == 'no' ) {
$meta_query[] = array(
'key' => '_hide_if_out_of_stock',
'compare' => 'NOT EXISTS'
);
}
$q->set( 'meta_query', $meta_query );
}