Добрый день!
Использую на сайте сортировку по умолчанию товаров по цене (возрастание и убывание цены), но есть проблема - сортирует без учета названия (алфавитный порядок).
Нашел код сортировки по названию. А по цене используется встроенная сортировка.
Как объединить сортировку по цене с сортировкой по алфавиту, есть у кого рабочий вариант? Можно за вознаграждение.
WP Версия 5.6
WC Версия 4.9.1
вариант сортировки: По названию
add_filter( 'woocommerce_get_catalog_ordering_args', 'custom_woocommerce_get_catalog_ordering_name_args' );
function custom_woocommerce_get_catalog_ordering_name_args( $args ) {
$orderby_value = isset( $_GET['orderby'] ) ? wc_clean( $_GET['orderby'] ) : apply_filters( 'woocommerce_default_catalog_orderby', get_option( 'woocommerce_default_catalog_orderby' ) );
if ( 'name_list' == $orderby_value ) {
$args['orderby'] = 'name';
$args['order'] = 'ASC';
$args['meta_key'] = '';
}
return $args;
};
add_filter( 'woocommerce_default_catalog_orderby_options', 'custom_woocommerce_catalog_name_orderby' );
add_filter( 'woocommerce_catalog_orderby', 'custom_woocommerce_catalog_name_orderby', 1 );
function custom_woocommerce_catalog_name_orderby( $sortby ) {
$sortby['name_list'] = 'По названию';
return $sortby;
};
Видел такой вариант для двойной сортировки, не заработал:
add_action( 'pre_get_posts', 'mik_exclude_category' );
function mik_exclude_category( $query ) {
if ( $query->is_main_query() ) {
$query->set( 'orderby', array('price' => 'ASC', 'name' => 'ASC') );
}
}