art_web
@art_web

Как объединить сортировку по цене и в алфавитном порядке?

Добрый день!

Использую на сайте сортировку по умолчанию товаров по цене (возрастание и убывание цены), но есть проблема - сортирует без учета названия (алфавитный порядок).
Нашел код сортировки по названию. А по цене используется встроенная сортировка.
Как объединить сортировку по цене с сортировкой по алфавиту, есть у кого рабочий вариант? Можно за вознаграждение.

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') );
    }
}
  • Вопрос задан
  • 118 просмотров
Решения вопроса 1
Попробуйте так
if ( 'name_list' == $orderby_value ) {
        $args['orderby'] = 'meta_value_num name';
        $args['order'] = 'ASC'; // (или 'DESC';)
        $args['meta_key'] = '_price';
    }
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы