nirfrost 11 декабря 2013 0 7
Добрый вечер нужен Фильтр по параметрам для ShopModx как это сделано в Shopkeeper
можно как его прикрутить?
просто из за одного фильтра не хочеться использовать Shopkeeper вместо ShopModx

Заранее спасибо!!!
7 комментариев
Fi1osof1
Fi1osof 11 декабря 2013г в 20:29 #
Добрый день!
Вы имеете ввиду смарт-фильтры, или просто поиск по параметрам?
n
nirfrost 11 декабря 2013г в 21:14 #
вот как тут demo-revo.modx-shopkeeper.ru/katalog/katalog-1/telefonyi/
слева где цена
ползунок и 2 поля поднизом мин цена и макс
n
nirfrost 11 декабря 2013г в 21:53 #
корректировка вот тут слева demo-revo.modx-shopkeeper.ru/katalog/katalog-2/telefonyi/
Fi1osof1
Fi1osof 11 декабря 2013г в 22:22 #
Нет, до этого мы еще не добрались (сами работаем над более важными моментами сейчас, а специально никто еще не заказывал). Но примерно такое вот здесь делалось: shop.ex-addicts.ru/catalog
Я думаю, что полноценный такой фильтр раньше чем месяца через два ждать не придется, только если кто-то другой не сделает его.
Fi1osof1
Fi1osof 11 декабря 2013г в 22:23 #
Общий механизм поиска по параметрам описан здесь: modxclub.ru/blog/voprosy-spetsyalistov/256.html
Может и сами сможете сделать.
Eo_Narique1
Eo_Narique 26 декабря 2014г в 14:05 #
не нашел решилось это или нет,
предлагаю свой вариант.


        if($this->getProperty('sm_price')){
            $params = $this->getProperty('sm_price');
            $q = array();
            $q[] = "Product.resource_id = {$this->classKey}.id";
            foreach($params as $key=>$p){
                $q[] = 'Product.sm_price '.$key.' '.$p;
            }
            $c->innerJoin('ShopmodxProduct',  'Product', implode(' AND ',$q));                        
        }else{ $c->innerJoin('ShopmodxProduct', 'Product'); }

в процессоре web/catalog/category/products/getdata

и до вызова процессора

{$params["sm_price"] = [">=" => $prices.0, "<=" => $prices.1]}
Fi1osof1
Fi1osof 26 декабря 2014г в 21:02 #
<< $c->innerJoin('ShopmodxProduct', 'Product');
Это не требуется, так как web/catalog/category/products/getdata расширяет web/catalog/products/getdata, в котором уже добавлено условие на таблицу.
if($this->getProperty('sm_price')){
            $params = $this->getProperty('sm_price');
Это тоже лучше упростить до
if($params = $this->getProperty('sm_price')){


Итоговый код (без лишних else):
if($params = $this->getProperty('sm_price')){
    $q = array();
    foreach($params as $key=>$p){
        $q[] = 'Product.sm_price '.$key.' '.$p;
    }
    $query->where($q);                       
}


Но это если рассматривать именно ваш код. А вообще правильней просто добавить $where еще перед вызовом процессора.
{$params.where[] = «sm_price between {$prices.0} and {$prices.1}»}
Авторизуйтесь или зарегистрируйтесь (можно через соцсети ), чтобы оставлять комментарии.