HostCMS в корне магазина вывести товары для категорий

По умолчанию в корне магазина /shop/ видны только категории без товаров. По этому было необходимость вывести список товаров для каждой группы. Например:

  • «Группа-А»
    • Товар-1
    • Товар-2
    • [...]
    • Товар-N
  • «Группа-Б»
    • Товар-1
    • Товар-2
    • [...]
    • Товар-N
  • [...]

Такое решение необходимо было сделать только в корне магазина /shop/. А в остальных случаях работает стандартно. Для этого написал Хук с проверкой. Например в ТДС магазина

if ($Shop_Controller_Show->group == 0)
{
    Core_Event::attach('shop_group.onBeforeGetXml', array('Shop_Group_Observer', 'onBeforeGetXml'));
}

Пишем класс наблюдателя, размещаем его в modules/shop/group/observer.php

class Shop_Group_Observer
{
    static public function onBeforeGetXml($object, $args)
    {
        if (is_object(Core_Page::instance()->object)
            && get_class(Core_Page::instance()->object) == 'Shop_Controller_Show')
        {
            if (Core_Page::instance()->object->group == 0)
            {
                // Получаем список валют магазина
                $aShop_Currencies = Core_Entity::factory('Shop_Currency')->findAll();

                $query_tax = 'IF(`shop_taxes`.`tax_is_included` IS NULL OR `shop_taxes`.`tax_is_included` = 1, 0, `shop_items`.`price` * `shop_taxes`.`rate` / 100)';
                $query_currency_switch = "`shop_items`.`price` + {$query_tax}";
                foreach ($aShop_Currencies as $oShop_Currency)
                {
                    // Получаем коэффициент пересчета для каждой валюты
                    $currency_coefficient = Shop_Controller::instance()->getCurrencyCoefficientInShopCurrency(
                        $oShop_Currency, $object->Shop->Shop_Currency
                    );

                    $query_currency_switch = "IF (`shop_items`.`shop_currency_id` = '{$oShop_Currency->id}', IF (COUNT(`shop_discounts`.`id`), ((`shop_items`.`price` + {$query_tax}) * (1 - SUM(DISTINCT IF(`shop_discounts`.`type` = 0, `shop_discounts`.`value`, 0)) / 100)) * {$currency_coefficient} - SUM(DISTINCT IF(`shop_discounts`.`type`, `shop_discounts`.`value`, 0)), (`shop_items`.`price`) * {$currency_coefficient}), {$query_currency_switch})";
                }

                $current_date = date('Y-m-d H:i:s');

                $oShop_Items = $object->Shop->Shop_Items;
                $oShop_Items->queryBuilder()
                    ->clearSelect()
                    ->select('shop_items.*')
                    ->select(array(Core_QueryBuilder::expression($query_currency_switch), 'absolute_price'))
                    ->leftJoin('shop_item_discounts', 'shop_items.id', '=', 'shop_item_discounts.shop_item_id')
                    ->leftJoin('shop_discounts', 'shop_item_discounts.shop_discount_id', '=', 'shop_discounts.id', array(
                        array('AND ' => array('shop_discounts.active', '=', 1)),
                        array('AND ' => array('shop_discounts.deleted', '=', 0)),
                        array('AND' => array('shop_discounts.start_datetime', '<=', $current_date)),
                        array('AND (' => array('shop_discounts.end_datetime', '>=', $current_date)),
                        array('OR' => array('shop_discounts.end_datetime', '=', '0000-00-00 00:00:00')),
                        array(')' => NULL)
                    ))
                    ->leftJoin('shop_taxes', 'shop_taxes.id', '=', 'shop_items.shop_tax_id')
                    ->where('shop_items.shop_group_id', '=', $object->id)
                    ->groupBy('shop_items.id')
                    ->clearOrderBy()
                    ->orderBy('absolute_price', 'ASC')
                    ->limit(20);

                $aShop_Items = $oShop_Items->findAll(FALSE);

                // XML-сущность
                $oGoodsXmlEntity = Core::factory('Core_Xml_Entity')->name('goods');
                $object->addEntity($oGoodsXmlEntity);

                foreach ($aShop_Items as $oShop_Item)
                {
                    $oGoodsXmlEntity->addEntity(
                        $oShop_Item
                            ->addForbiddenTag('text')
                            ->addForbiddenTag('description')
                            ->addForbiddenTag('shop_producer')
                            ->showXmlComments(FALSE)
                            ->showXmlAssociatedItems(FALSE)
                            ->showXmlModifications(FALSE)
                            ->showXmlSpecialprices(FALSE)
                            ->showXmlTags(FALSE)
                            ->showXmlWarehousesItems(FALSE)
                            ->showXmlSiteuser(FALSE)
                            ->showXmlProperties(FALSE)
                            ->showXmlSets(FALSE)

                    );

                }
            }
        }
    }
}

Тут можно отметить что товары отсортированы по цене по убыванию.

  • 14 219 просмотров