сортировать товары по новинкам, скидкам, продажам, отзывам »на странице списка товаров

10

На странице списка продуктов мы можем видеть сортировку по «Позиции, имени, цене», как в стандартном Magento.

Как сортировать по

  1. новейшие продукты (загружены недавно)
  2. Скидка (продукты с наибольшей скидкой в ​​первую очередь)
  3. Бестселлер (сначала самые продаваемые товары)
  4. Отзывы (продукты с высоким рейтингом отображаются в первую очередь)

Пожалуйста, дайте мне знать, если вам нужны какие-либо разъяснения ...

Ребенок в Мадженто
источник

Ответы:

7

для -> Недавно просмотренные смотри здесь

для -> сортировка по рейтингу

Скопируйте файл

app/code/core/Mage/Catalog/Block/Product/List.php в

app/code/local/Mage/Catalog/Block/Product/List.php

в list.phpнаходке для этой линии

$this->_productCollection =$layer->getProductCollection();

который будет примерно, line no 86добавьте следующий код после этого

$this->_productCollection->joinField('rating_summary', 'review_entity_summary', 'rating_summary', 'entity_pk_value=entity_id', array('entity_type'=>1, 'store_id'=> Mage::app()->getStore()->getId()), 'left')

сейчас копируй

app/code/core/Mage/Catalog/Model/Config.php в

app/code/local/Mage/Catalog/Model/Config.php

в config.php найдите этот код

$options = array(
    'position'  => Mage::helper('catalog')->__('Position')
);

заменить

$options = array(
    'position'  => Mage::helper('catalog')->__('Position'),
    'rating_summary' => Mage::helper('catalog')->__('Rating')
);

- >> для BESTSELLER

следуйте этой процедуре, создайте именование папок Inchooи внутри этого места папок Catalogи внутри каталога создайте 3 папки Block, etcи Modelв Blockдобавьте Productв Productдобавьте Listи в Listсоздайте файл и назовите его как Toolbar.phpи добавьте этот код в него

<?php
class Inchoo_Catalog_Block_Product_List_Toolbar extends Mage_Catalog_Block_Product_List_Toolbar
{
    public function setCollection($collection)
    {
        parent::setCollection($collection);

        if ($this->getCurrentOrder()) {
            if($this->getCurrentOrder() == 'qty_ordered') {
                $this->getCollection()->getSelect()
                     ->joinLeft(
                            array('sfoi' => $collection->getResource()->getTable('sales/order_item')),
                             'e.entity_id = sfoi.product_id',
                             array('qty_ordered' => 'SUM(sfoi.qty_ordered)')
                         )
                     ->group('e.entity_id')
                     ->order('qty_ordered ' . $this->getCurrentDirection());
            } else {
                $this->getCollection()
                     ->setOrder($this->getCurrentOrder(), $this->getCurrentDirection())->getSelect();
            }
        }

        return $this;
    }
}

Теперь в etcпапке создайте файл с именем config.xmlи добавьте этот код

<config>
    <modules>
        <Inchoo_Catalog>
            <version>0.1.0</version>
        </Inchoo_Catalog>
    </modules>
    <global>
        <blocks>
            <catalog>
                <rewrite>
                    <product_list_toolbar>Inchoo_Catalog_Block_Product_List_Toolbar</product_list_toolbar>
                </rewrite>
            </catalog>
        </blocks>
        <models>
            <catalog>
                <rewrite>
                    <config>Inchoo_Catalog_Model_Config</config>
                </rewrite>
            </catalog>
            <catalog_resource>
                <rewrite>
                    <product_collection>Inchoo_Catalog_Model_Resource_Product_Collection</product_collection>
                </rewrite>
            </catalog_resource>
        </models>
    </global>
</config>

Теперь Modelсоздайте имя файла Config.phpи добавьте этот код.

<?php class Inchoo_Catalog_Model_Config extends Mage_Catalog_Model_Config
{
    public function getAttributeUsedForSortByArray()
    {
        return array_merge(
            parent::getAttributeUsedForSortByArray(),
            array('qty_ordered' => Mage::helper('catalog')->__('Sold quantity'))
        );
    }
}

также создайте Resourceпапку внутри Modelи внутри Resourceпапки создайте Productпапку и создайте имя файла Collection.phpи добавьте следующий код.

<?php
class Inchoo_Catalog_Model_Resource_Product_Collection extends Mage_Catalog_Model_Resource_Product_Collection
{
    protected function _getSelectCountSql($select = null, $resetLeftJoins = true)
    {
       $this->_renderFilters();
       $countSelect = (is_null($select)) ?
           $this->_getClearSelect() :
           $this->_buildClearSelect($select);

       if(count($countSelect->getPart(Zend_Db_Select::GROUP)) > 0) {
           $countSelect->reset(Zend_Db_Select::GROUP);
       }

       $countSelect->columns('COUNT(DISTINCT e.entity_id)');
       if ($resetLeftJoins) {
           $countSelect->resetJoinLeft();
       }
       return $countSelect;
    }
}

Теперь, наконец, активируйте этот модуль, app/etc/modulesсоздав файл и Inchoo_Catalog.xmlдобавив этот код.

<?xml version="1.0"?>
<!--
/**
 * Magento
 *
 * NOTICE OF LICENSE
 *
 * This source file is subject to the Academic Free License (AFL 3.0)
 * that is bundled with this package in the file LICENSE_AFL.txt.
 * It is also available through the world-wide-web at this URL:
 * http://opensource.org/licenses/afl-3.0.php
 * If you did not receive a copy of the license and are unable to
 * obtain it through the world-wide-web, please send an email
 * to license@magentocommerce.com so we can send you a copy immediately.
 *
 * DISCLAIMER
 *
 * Do not edit or add to this file if you wish to upgrade Magento to newer
 * versions in the future. If you wish to customize Magento for your
 * needs please refer to http://www.magentocommerce.com for more information.
 *
 * @category    Mage
 * @package     Mage_Connect
 * @copyright   Copyright (c) 2014 Magento Inc. (http://www.magentocommerce.com)
 * @license     http://opensource.org/licenses/afl-3.0.php  Academic Free License (AFL 3.0)
 */
-->
<config>
    <modules>
        <Inchoo_Catalog>
            <active>true</active>
            <codePool>community</codePool>
            <depends />
        </Inchoo_Catalog>
    </modules>
</config>

и потому что SALEя предлагаю вам это расширение, так как я не могу найти какой-либо программный способ достичь этого.

dh47
источник
привет, большое спасибо за ответ, скоро проверю и расскажу ....
Малышка в Magento
Есть ли что-то еще, что я должен сделать, чтобы получить опцию «рейтинг» в «сортировать по» на странице списка продуктов. я сделал кеш и управление индексами, но опция рейтинга не отображается в разделе: сортировать по "на странице со списком продуктов.
Baby in Magento
pastebin.com/5403TsLa => list.php pastebin.com/Z7WK7C1m => config.php, пожалуйста, проверьте вышеуказанные файлы ....
Baby in Magento
хм, код работает нормально для меня, я не могу понять, в чем вина твоего
dh47
я проверю это еще раз ....
Малыш в Magento