Последние темы


Интересно ли вам наличие в 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

 

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

  • Z

    Спасибо, действительно проще создать отдельно.

    Читать далее
  • Но проблема в том, что эта старая цена "дублируется" в плесхолдер "Дополнительных услуг" - [[+addit_data]].

    Можно не использовать [[+addit_data]], а выводить параметры по-отдельности.

    Цитата из документации:

    [[+shk_любой доп.параметр]] - любой доп. параметр, выбранный при добавлении товара в корзину (из [[+addit_data]]), например [[+shk_param1]].
    Если параметры сделаны в виде чекбоксов, то чтобы вывести отдельно каждый из них, нужно добавлять индекс (номер от нуля) для параметров следующих за первым.
    Пример: [[+shk_param1]], [[+shk_param1_1]], [[+shk_param1_2]] ...
    [[+shk_любой доп.параметр_price]] - цена доп.параметра. Пример: [[+shk_param1_price]].

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

    Доброго времени суток. Не могу разобраться, как передать данные migx-поля в корзину в плейсхолдер без "дублирования" в [[+addit_data]]
    Суть в чем: У меня есть 2 цены у товара (со скидкой и без скидки) Форма для отправки в корзину:

    <form action="[[~[[*resource_id]]? &scheme=`abs`]][[*alias]].html" method="post"> <input type="hidden" name="shk-id" value="[[*id]]" /> <input type="hidden" name="shk-name" value="[[*pagetitle]]" /> <input type="hidden" name="price_old__[[*id]]__add" value="[[*price_old]]" /> <input type="hidden" name="shk-count" value="1" /> <div class="product-price"> Цена: <span class="shk-price">[[!*price:shk_curr_rate:num_format]]</span> Старая цена - <span class="shk-price-old">[[+price_old]]</span> [[!+shk_currency]] </div> <div class="padding-lr-30"> <h5>Дополнительные услуги</h5> [[*param1]] </div> <div class="product-price"> <button class="btn btn-lg btn-primary" type="submit" class="shk-but">В корзину</button> </div> </form>

    Данные со "старой ценой" в корзину попадают нормально и выводится в нужном месте в плейсхолдере:
    [[+shk_price_old]]
    Но проблема в том, что эта старая цена "дублируется" в плесхолдер "Дополнительных услуг" - [[+addit_data]]. Как сделать чтобы старая цена не выводилась в [[+addit_data]]? Или может я как то не правильно передаю MIGX-параметр в корзину ? Заранее спасибо.

    Читать далее
  • Фотографии, как я понял, это второй вопрос. Я по нему пока ничего не отвечал и не просил информации. Это не отменяет того, что в вашем конфиге есть ошибка, о которой я писал выше. Не нужно задавать разные вопросы в одной теме, чтобы не было путаницы.
    http://forum.modx-shopkeeper.ru/topic/15/рекомендации-по-оформлению-темы-с-вопросом

    Читать далее