Новости

Интересно ли вам наличие в TagManager/ViewSwitch сортировки по двум полям сразу?

  • Приведу пример, у меня на сайте для пользователя доступна сортировка по цене.
    При этом в каталоге есть товары, которых нет в наличии. Чтобы не плодить заказы на отсутствующие товары и не мучать пользователя фильтрами по наличию, я просто по умолчанию ранжирую по наличию, а затем по цене:
    Товар 1 в наличии 200 руб
    Товар 2 в наличии 500 руб
    .....
    Товар N нет в наличии 100 руб
    Товар N+1 нет в наличии 300 руб

    Выходит, как мне кажется, логично - если пользователь не нашел ничего, что бы ему понравилось среди товаров в наличии, он дойдет до отсутствующих товаров, возможно его зацепит что-то из них. Можно будет заказать, но придется долго ждать.

    Насколько вам интересно, наличие такой скрытой сортировки по 2му полю в tagManager?

    Реализуется легко, нужно будет доп параметр завести и небольшую правку в tmCatalog добавить. Я могу pull-request написать на это.

  • Если решение универсальное, то отправляйте пулл-реквестом.

  • @Andchir мне кажется оно универсальное и главное - не рушит логику продуктов.

    Итак, у getProducts помимо сортировок по одному полю - sortby, есть
    orderby - Json строка, где можно сортировать по нескольким параметрам сразу.

    (В TagManager эта строка никак не используется, напротив, если ее задать, то перестают работать сортировки.)

    Вот ее я и предлагаю задействовать и считать, что в этом параметре мы задаем сортировку по умолчанию. Допустим наличие товара храним в ТВ stock.
    Тогда в наборе параметров вывода каталога укажем

    orderby -> {"stock":"DESC"}
    

    Но, сейчас этот параметр имеет превалирующее значение над сортировками. Т.е. что бы мы ни задали в sortby все будет отсортировано по orderby.

    Чтобы учитывались обе сортировки предлагаю их объединить, внеся три строчки в tmCatalog выделил комментариями:

    $sortby = isset($_GET['sortby']) && !is_array($_GET['sortby']) ? htmlspecialchars(trim($_GET['sortby'])) : $modx->getOption('sortby',$snippetProperties,'pagetitle');
    $sortdir = isset($_GET['sortdir']) && !is_array($_GET['sortdir']) ? htmlspecialchars(trim($_GET['sortdir'])) : $modx->getOption('sortdir',$snippetProperties,'asc');
    if(strtolower($sortdir)=='rand' || strtolower($sortby)=='rand') { $sortby = 'RAND()'; }
    
    $sorting = $tm_catalog->getSorting($sortby, $sortdir);
    
    /*часть про orderby start*/
    
    $orderby = isset($snippetProperties['orderby']) ? json_decode($snippetProperties['orderby'], true) : array();
    $orderby[$sorting['sortby']] =$sorting['sortdir'];
    $sorting['orderby']=json_encode($orderby);
    
    /*end часть про orderby*/
    
    $properties = array_merge($config, $snippetProperties, $sorting);
    

    Вот и все, может не очень элегантно, но просто и не рушит логику.

  • @slaad а куда pull присылать? На github нет tagManager.

  • @Andchir спасибо, огромное! Не догадался там искать.

    Все добавил: https://github.com/andchir/shopkeeper3/pull/19

 

Последние комментарии

  • M

    @Andchir
    Да, в TM2 в админке фильтр age включен. Все данные из TV подтянулись, все норм.

    Читать далее
  • В компоненте в админке фильтры есть?

    Читать далее
  • M

    Ломаю голову над запуском Tagmanager2 на простом сайте с выводом обычных item-ов для последующей фильтрации. Делую все по инструкции. Запустил tmCatalog, все отображается:

    [[!tmCatalog? &cache=`1` &elementClass=`modSnippet` &element=`getProducts` &tpl=`filtr_tpl` &sortbyTV=`age` &sortdirTV=`ASC` &parents=`3` &limit=`0` &debug=`0` ]]

    Чанк вывода каждого itema имеет следующий вид:

    <div class="col-xl-4" style="padding-left: 5px; padding-right: 5px; float: left;"> <div class="post-02 post-02__style-02 js-post-effect"> <div class="post-02__media"> <a href="[[~[[+id]]]]"> [[getImageList? &tvname=`slider` &docid=`[[+id]]` &limit=`1` &tpl=`@CODE:<img src="[[+slide]]" alt="[[+alt]]" />` ]] </a></div> <div class="post-02__body"> <h2 class="post-02__title"><a href="[[~[[+id]]]]">[[!pdoField? &id=`[[+id]]` &field=`name`]]</a></h2> <div class="post-02__department">[[!pdoField? &id=`[[+id]]` &field=`seo_tag`]]</div> <div class="post-02__content"> <div class="post-02__description"> [[pdoField:ellipsis=`200`? &id=`[[+id]]` &field=`specification`]] <ul> <li><span class="primary-color">Age</span>[[!pdoField? &id=`[[+id]]` &field=`age`]]</li> <li><span class="primary-color">Dress Size</span>[[!pdoField? &id=`[[+id]]` &field=`dress_size`]]</li> <li><span class="primary-color">Height</span>[[!pdoField? &id=`[[+id]]` &field=`height`]] cm</li> <li><span class="primary-color">Weight</span>[[!pdoField? &id=`[[+id]]` &field=`weight`]] kg</li> </ul> </div> <a class="post-02__link" href="[[~[[+id]]]]">View detail</a> </div> </div> </div> </div>

    filter.js имеет следующий вид. Пока решил фильтровать только числовое значение age:

    config: { filters_cont: '#filters',//Селектор оберточного элемента блоков с фильтрами sortby: 'pagetitle',//Имя поля сортировки по умолчанию sortdir: 'asc',//Направление сортировки по умолчанию numeric: ['age'],//Имена доп. полей с числовыми значениями multitags: [''],//Имена доп. полей с множественными значениями guard_key: '#',//Разделитель для множественных значений products_cont: '#products',//Селектор контейнера с выводом товаров filter_slider: 'div.range-slider',//Селектор слайдеров (ползунок для числовых значений) filter_slider_cont: 'div.filter_slider',//Селектор контейнера со слайдером pages_cont1: '#pages',//Селектор контейнера с постраничной навигацией pages_cont2: '#pages2',//Селектор второго контейнера с постраничной навигацией. Если нет, оставить пустым. active_page_selector: '.current',//селектор номера текущей страницы внутри контейнера (pages_cont) filters_type: 'default',//Тип фильтрации. Возможные значения: // default (показ числа товаров по каждому фильтру и блокирование пустых вариантов), // only_block (только блокирование пустых париантов), // none (не показывать цифры и не блокировать) filter_delay: 700,//Задержка до отправления запроса на сервер (сбрасывается после каждой отметки фильтра) price_field: 'price',//Название поля или TV цены товара multi_currency: true,//Мультивалютность включить / выключить (true/false) base_url: '/', ajax_url: 'assets/components/tag_manager2/connector_fe.php', ajax_loader: 'assets/components/tag_manager2/img/ajax-loader2.gif' },

    Все скрипты подключи вручную, все отображается внизу страницы, проверял.
    Сам tmFilters не отображается хоть убей. Вывожу:

    <div id="filters"> [[tmFilters? &filterNumericTpl=`tm2_filterNumericTpl` &filterNumericOuterTpl=`tm2_filterOuterTpl` &jsScript=`0` &jsMap=`1` &filtersType=`filters` ]] <form action="[[~[[*id]]]]" method="get"> <input type="hidden" name="page_id" value="[[*id]]" disabled="disabled" /> [[+filters]] <button id="clear" class="btn btn-danger btn-sm" type="button" onclick="tmFilters.resetFilters(); return false;">Сбросить</button> </form> </div>

    При выводе на странице выводится только кнопка. Фильтров как и не существует. Я понимаю, если бы кривенько вывелись чанки с фильтром и он не фильтровал, здесь же сам фильтр никак не хочет выводиться в бэкенд. Кто с таким сталкивался? Куда копать?

    Читать далее
  • @Andchir Спасибо!!!
    Все перепробовал кроме [[+note]]
    В письме со статусом отправлен, чтобы трек-номер отправлять покупателю. Все работает. Еще раз спасибо.

    Читать далее