Надо сделать сортировку по кастомному полю, и с ней же фильтр по определенному параметру.
Нашел что надо через фильтры woocommerce_catalog_orderby и woocommerce_get_catalog_ordering_args делать свою сортировку, а вот как задать параметры не пойму.
пробовал в woocommerce_get_catalog_ordering_args выводить только товары в наличии больше 0, ничего не меняется, что я делаю не так?
Зарегистрировал свой тип сортировки
function sv_custom_woocommerce_catalog_orderby( $sortby ) {
$sortby['my-sort'] = 'Only in stock';
return $sortby;
}
add_filter( 'woocommerce_default_catalog_orderby_options', 'sv_custom_woocommerce_catalog_orderby' );
add_filter( 'woocommerce_catalog_orderby', 'sv_custom_woocommerce_catalog_orderby' );
Ну и сам фильтр сортировок
function custom_woocommerce_shop_ordering( $sort_args ) {
$orderby_value = isset( $_GET['orderby'] ) ? woocommerce_clean( $_GET['orderby'] ) : apply_filters( 'woocommerce_default_catalog_orderby', get_option( 'woocommerce_default_catalog_orderby' ) );
if ( 'my-sort' == $orderby_value ) {
//тут параметры сортировки
}
return $sort_args;
}
add_filter( 'woocommerce_get_catalog_ordering_args', 'custom_woocommerce_shop_ordering' );
Пробовал так
$sort_args['meta_query'] = array(array(
'key' => '_stock',
'value' => 0,
'compare' => '>',
));
И так
$sort_args['meta_key'] = '_stock';
$sort_args['meta_value'] = '0';
$sort_args['meta_compare'] = '>';