diff --git a/modules/blocklayered/blocklayered.php b/modules/blocklayered/blocklayered.php index 7346ca95c..9a7987e7b 100644 --- a/modules/blocklayered/blocklayered.php +++ b/modules/blocklayered/blocklayered.php @@ -2190,7 +2190,10 @@ class BlockLayered extends Module break; + case 'category': + $this->user_groups = ($this->context->customer->isLogged() ? $this->context->customer->getGroups() : array(Configuration::get('PS_UNIDENTIFIED_GROUP'))); + $depth = Configuration::get('PS_LAYERED_FILTER_CATEGORY_DEPTH'); if ($depth === false) $depth = 1; @@ -2206,9 +2209,11 @@ class BlockLayered extends Module $sql_query['group'] = ') count_products FROM '._DB_PREFIX_.'category c LEFT JOIN '._DB_PREFIX_.'category_lang cl ON (cl.id_category = c.id_category AND cl.`id_shop` = '.(int)Context::getContext()->shop->id.' and cl.id_lang = '.$id_lang.') + RIGHT JOIN '._DB_PREFIX_.'category_group cg ON (cg.id_category = c.id_category AND cg.`id_group` IN ('.implode(', ', $this->user_groups).')) WHERE c.nleft > '.(int)$parent->nleft.' AND c.nright < '.(int)$parent->nright.' '.($depth ? 'AND c.level_depth <= '.($parent->level_depth+(int)$depth) : '').' + AND c.active = 1 GROUP BY c.id_category ORDER BY c.nleft, c.position'; } diff --git a/themes/default-bootstrap/product-list.tpl b/themes/default-bootstrap/product-list.tpl index 30c05c5e4..14ef8803c 100644 --- a/themes/default-bootstrap/product-list.tpl +++ b/themes/default-bootstrap/product-list.tpl @@ -76,7 +76,8 @@
'+ $(element).find('.product-desc').html() + '
'; var colorList = $(element).find('.color-list-container').html(); @@ -300,17 +301,17 @@ html += ''+ $(element).find('.product-desc').html() + '
'; + html += ''+ $(element).find('.product-desc').html() + '
'; var price = $(element).find('.content_price').html(); // check : catalog mode is enabled if (price != null) { html += '