Вывод каталога товаров на главную.

#
Вывод каталога товаров на главную.
Всем привет!
к сожалению в этом движке не очень понимаю.
(Hostcms 6.8.2)

Подскажите пожалуйста,
PHP код типовой динамической страницы

<?php

$Shop_Controller_Show = Core_Page::instance()->object;

$xslName = $Shop_Controller_Show->item
   ? Core_Array::get(Core_Page::instance()->libParams, 'shopItemXsl')
   : Core_Array::get(Core_Page::instance()->libParams, 'shopXsl');

$Shop_Controller_Show->addEntity(
   Core::factory('Core_Xml_Entity')
      ->name('ТекущаяГруппа')->value($Shop_Controller_Show->group)
)->addEntity(
   Core::factory('Core_Xml_Entity')
      ->name('show_comments')->value(Core_Array::get(Core_Page::instance()->libParams, 'showComments', 1))
)->addEntity(
   Core::factory('Core_Xml_Entity')
      ->name('show_add_comments')->value(Core_Array::get(Core_Page::instance()->libParams, 'showAddComment', 2))
);

$Shop_Controller_Show
   ->groupsMode('all')
   ->tags(FALSE)
   ->comments(FALSE)
   ->associatedItems(FALSE)
   ->modifications(FALSE);

if ($Shop_Controller_Show->item == 0)
{

   $Shop_Controller_Show->itemsForbiddenTags(array('text'));

   $oShop = $Shop_Controller_Show->getEntity();

   $oProperty = Core_Entity::factory('Property', 83);
   $pValue = $oProperty->getValues($Shop_Controller_Show->group, false);
   if (count($pValue) && $pValue[0]->value) {
      //$Shop_Controller_Show->group = FALSE;
      $_GET['filter'] = 1;
      $_GET['group'] = 'all';

      $oPropertySize = Core_Entity::factory('Property', 79);
      $pValueSize = $oPropertySize->getValues($Shop_Controller_Show->group, false);
      if ($pValueSize[0]->value) $_GET['property_63'] = $pValueSize[0]->value;

      $oPropertySurface = Core_Entity::factory('Property', 80);
      $pValueSurface = $oPropertySurface->getValues($Shop_Controller_Show->group, false);
      if ($pValueSurface[0]->value) $_GET['property_68'] = $pValueSurface[0]->value;

      $oPropertyMark = Core_Entity::factory('Property', 81);
      $pValueMark = $oPropertyMark->getValues($Shop_Controller_Show->group, false);
      if ($pValueMark[0]->value) $_GET['property_67'] = $pValueMark[0]->value;

      $oPropertyColor = Core_Entity::factory('Property', 82);
      $pValueColor = $oPropertyColor->getValues($Shop_Controller_Show->group, false);
      if ($pValueColor[0]->value) $_GET['property_64'] = $pValueColor[0]->value;

echo '<div style="display: none;">';
   //print_r($_GET);
echo '</div>';
}

   if (Core_Array::getGet('filter') || Core_Array::getGet('sorting'))
   {
      $Shop_Controller_Show->addEntity(
         Core::factory('Core_Xml_Entity')
            ->name('filter')->value(1)
      );

      $sorting = intval(Core_Array::getGet('sorting'));
      $Shop_Controller_Show->addEntity(
         Core::factory('Core_Xml_Entity')
            ->name('sorting')->value($sorting)
      );
      $Shop_Controller_Show->addCacheSignature('sorting=' . $sorting);

/* Тут код для фильтра по производителям :: фильтруем */
      //Producers
      if (Core_Array::getGet('producer_id'))
      {
         $iProducerId = intval(Core_Array::getGet('producer_id'));
         $Shop_Controller_Show->addEntity(
            Core::factory('Core_Xml_Entity')
               ->name('producer_id')->value($iProducerId)
            );

         $Shop_Controller_Show->shopItems()
            ->queryBuilder()
            ->select('shop_items.*')
            ->where('shop_items.shop_producer_id', '=', $iProducerId);
      }
/* Тут код для фильтра по производителям :: фильтруем :: конец */

      // Prices
      $price_from = intval(Core_Array::getGet('price_from'));
      $price_to = intval(Core_Array::getGet('price_to'));
      if ($price_from || $price_to || $sorting == 1 || $sorting == 2)
      {
         // Получаем список валют магазина
         $aShop_Currencies = Core_Entity::factory('Shop_Currency')->findAll();

         $query_currency_switch = 'price';
         foreach ($aShop_Currencies as $oShop_Currency)
         {
            // Получаем коэффициент пересчета для каждой валюты
            $currency_coefficient = Shop_Controller::instance()->getCurrencyCoefficientInShopCurrency(
               $oShop_Currency, $oShop->Shop_Currency
            );

            $query_currency_switch = "IF (`shop_items`.`shop_currency_id` = '{$oShop_Currency->id}', IF (shop_discounts.percent, price * (100 - shop_discounts.percent) * {$currency_coefficient} / 100, shop_items.price * {$currency_coefficient}), {$query_currency_switch})";
         }

         $current_date = date('Y-m-d H:i:s');
         $Shop_Controller_Show->shopItems()
            ->queryBuilder()
            ->select(array(Core_QueryBuilder::expression($query_currency_switch), 'absolute_price'))
            ->leftJoin('shop_item_discounts', 'shop_items.id', '=', 'shop_item_discounts.id')
            ->leftJoin('shop_discounts', 'shop_item_discounts.id', '=', 'shop_discounts.id', array(
               array('AND (' => array('shop_discounts.end_datetime', '>=', $current_date)),
               array('OR' => array('shop_discounts.end_datetime', '=', '0000-00-00 00:00:00')),
               array('AND' => array('shop_discounts.start_datetime', '<=', $current_date)),
               array(')' => NULL),
            ));

         if ($price_from)
         {
            $Shop_Controller_Show->shopItems()->queryBuilder()->having('absolute_price', '>=', $price_from) && $Shop_Controller_Show->addEntity(
               Core::factory('Core_Xml_Entity')
                  ->name('price_from')->value($price_from)
            );
            $Shop_Controller_Show->addCacheSignature('price_from=' . $price_from);
         }
         if ($price_to)
         {
            $Shop_Controller_Show->shopItems()->queryBuilder()->having('absolute_price', '<=', $price_to);
            $Shop_Controller_Show->addEntity(
               Core::factory('Core_Xml_Entity')
                  ->name('price_to')->value($price_to)
            );
            $Shop_Controller_Show->addCacheSignature('price_to=' . $price_to);
         }

         $Shop_Controller_Show->shopItems()->queryBuilder()
            ->clearOrderBy()
            ->orderBy('absolute_price', $sorting == 1 ? 'ASC' : 'DESC');
      }

      $sorting == 3 && $Shop_Controller_Show->shopItems()->queryBuilder()
         ->clearOrderBy()
         ->orderBy('shop_items.name', 'ASC');

      // Additional properties
      $oShop_Item_Property_List = Core_Entity::factory('Shop_Item_Property_List', $oShop->id);

      $aProperties = $Shop_Controller_Show->group !== FALSE && is_null($Shop_Controller_Show->tag)
         ? $oShop_Item_Property_List->getPropertiesForGroup($Shop_Controller_Show->group)
         : $oShop_Item_Property_List->Properties->findAll();

//print_r($aProperties);

      $aTmpProperties = array();
      $havingCount = 0;
      foreach ($aProperties as $oProperty)
      {
         // Св-во может иметь несколько значений
         $aPropertiesValue = Core_Array::getGet('property_' . $oProperty->id);
         if ($aPropertiesValue)
         {
            !is_array($aPropertiesValue) && $aPropertiesValue = array($aPropertiesValue);
            foreach ($aPropertiesValue as $sPropertyValue)
            {
               $aTmpProperties[] = array($oProperty, strval($sPropertyValue));
            }
            $havingCount++;
         }
         elseif (!is_null(Core_Array::getGet('property_' . $oProperty->id . '_from')))
         {
            // From ... to ...
            $aTmpProperties[] = array($oProperty, array(
               'from' => intval(Core_Array::getGet('property_' . $oProperty->id . '_from')),
               'to' => intval(Core_Array::getGet('property_' . $oProperty->id . '_to'))
            ));
            $havingCount++;
         }
      }

      if (count($aTmpProperties))
      {
         $aTableNames = array();

         $Shop_Controller_Show->shopItems()->queryBuilder()
            ->leftJoin('shop_item_properties', 'shop_items.shop_id', '=', 'shop_item_properties.shop_id')
            ->setAnd()
            ->open();

         reset($aTmpProperties);
         while(list(, list($oProperty, $propertyValue)) = each($aTmpProperties))
         {
            $tableName = $oProperty->createNewValue(0)->getTableName();

            !in_array($tableName, $aTableNames) && $aTableNames[] = $tableName;

            $Shop_Controller_Show->shopItems()->queryBuilder()
               ->where('shop_item_properties.property_id', '=', $oProperty->id);

            if (!is_array($propertyValue))
            {
               // Для строк фильтр LIKE %...%
               if ($oProperty->type == 1)
               {
                  $Shop_Controller_Show->shopItems()->queryBuilder()
                     ->where($tableName . '.value', 'LIKE', "%{$propertyValue}%");
               }
               else
               {
                  // Checkbox
                  $oProperty->type == 7 && $propertyValue != '' && $propertyValue = 1;

                  $Shop_Controller_Show->shopItems()->queryBuilder()
                     ->where($tableName . '.value', '=', $propertyValue);
               }

               $Shop_Controller_Show->shopItems()->queryBuilder()
                  ->setOr();

               $Shop_Controller_Show->addEntity(
                  Core::factory('Core_Xml_Entity')
                     ->name('property_' . $oProperty->id)->value($propertyValue)
               );
               $Shop_Controller_Show->addCacheSignature("property{$oProperty->id}={$propertyValue}");
            }
            else
            {
               $from = trim(strval(Core_Array::get($propertyValue, 'from')));
               $from && $Shop_Controller_Show->shopItems()->queryBuilder()
                  ->where($tableName . '.value', '>=', $from)
                  ->setAnd();
               $to = trim(strval(Core_Array::get($propertyValue, 'to')));
               $to && $Shop_Controller_Show->shopItems()->queryBuilder()
                  ->where($tableName . '.value', '<=', $to);

               $Shop_Controller_Show->shopItems()->queryBuilder()
                  ->setOr();

               $Shop_Controller_Show->addEntity(
                  Core::factory('Core_Xml_Entity')
                     ->name('property_' . $oProperty->id . '_from')->value($from)
               )->addEntity(
                  Core::factory('Core_Xml_Entity')
                     ->name('property_' . $oProperty->id . '_to')->value($to)
               );

               $Shop_Controller_Show
                  ->addCacheSignature("property{$oProperty->id}_from={$from}")
                  ->addCacheSignature("property{$oProperty->id}_to={$to}");
            }
         }

         $Shop_Controller_Show->shopItems()->queryBuilder()
            ->close()
            ->groupBy('shop_items.id')
            ->having('COUNT(shop_item_properties.id)', '=', $havingCount);

if (Core_Array::getGet('group') == 'all')
{
   $Shop_Controller_Show->shopItems()->queryBuilder()->where('shop_items.shop_group_id', '>', '0')->setOr();
}

         foreach ($aTableNames as $tableName)
         {
            $Shop_Controller_Show->shopItems()->queryBuilder()
               ->leftJoin($tableName, 'shop_items.id', '=', $tableName . '.entity_id',
                  array(
                     array('AND' => array('shop_item_properties.property_id', '=', Core_QueryBuilder::expression($tableName . '.property_id')))
                  )
               );
         }
      }
   }
}
else
{
   if (Core_Array::getPost('add_comment') && Core_Array::get(Core_Page::instance()->libParams, 'showComments', 1))
   {
      $oShop = $Shop_Controller_Show->getEntity();

      $Shop_Controller_Show->cache(FALSE);

      $oLastComment = Core_Entity::factory('Comment')->getLastCommentByIp(
         Core_Array::get($_SERVER, 'REMOTE_ADDR')
      );

      $oXmlCommentTag = Core::factory('Core_Xml_Entity')
         ->name('document');

      $siteuser_id = 0;
      if (Core::moduleIsActive('siteuser'))
      {
         $oSiteuser = Core_Entity::factory('Siteuser')->getCurrent();

         if ($oSiteuser)
         {
            $siteuser_id = $oSiteuser->id;
         }
      }

      $oComment = Core_Entity::factory('Comment');

      $allowable_tags = '<b><strong><i><em><br><p><u><strike><ul><ol><li>';
      $oComment->parent_id = intval(Core_Array::getPost('parent_id', 0));
      $oComment->active = $oShop->comment_active;
      $oComment->author = Core_Str::stripTags(Core_Array::getPost('author'));
      $oComment->email = Core_Str::stripTags(Core_Array::getPost('email'));
      $oComment->grade = intval(Core_Array::getPost('grade', 0));
      $oComment->subject = Core_Str::stripTags(Core_Array::getPost('subject'));
      $oComment->text = nl2br(Core_Str::stripTags(Core_Array::getPost('text'), $allowable_tags));
      $oComment->siteuser_id = $siteuser_id;

      $oShop_Item = Core_Entity::factory('Shop_Item', $Shop_Controller_Show->item);

      $oXmlCommentTag
         ->addEntity($oComment)
         ->addEntity($oShop_Item);

      if (is_null($oLastComment) || time() > Core_Date::sql2timestamp($oLastComment->datetime) + ADD_COMMENT_DELAY)
      {
         if ($oShop->use_captcha == 0 || $siteuser_id > 0 || Core_Captcha::valid(Core_Array::getPost('captcha_id'), Core_Array::getPost('captcha')))
         {
            $oComment->save();

            $oShop_Item->add($oComment);

            $oXmlCommentTag->addEntity($oShop);

            // Отправка письма администратору
            $sText = Xsl_Processor::instance()
               ->xml($oXmlCommentTag->getXml())
               ->xsl(Core_Entity::factory('Xsl')->getByName(Core_Array::get(Core_Page::instance()->libParams, 'addCommentAdminMailXsl')))
               ->process();

            Core_Mail::instance()
               ->to(EMAIL_TO)
               ->from(Core_Valid::email($oComment->email)
                  ? $oComment->email
                  : EMAIL_TO
               )
               ->subject(Core::_('Shop.comment_mail_subject'))
               ->message(trim($sText))
               ->contentType(Core_Array::get(Core_Page::instance()->libParams, 'commentMailNoticeType', 0) == 0
                  ? 'text/plain'
                  : 'text/html'
               )
               ->send();
         }
         else
         {
            $oXmlCommentTag->addEntity(Core::factory('Core_Xml_Entity')
               ->name('error_captcha')->value(1)
            );

            $Shop_Controller_Show->addEntity($oComment);
         }
      }
      else
      {
         $oXmlCommentTag->addEntity(Core::factory('Core_Xml_Entity')
            ->name('error_time')->value(1)
         );

         $Shop_Controller_Show->addEntity($oComment);
      }

      // Результат добавления комментария
      $xsl_result = Xsl_Processor::instance()
         ->xml($oXmlCommentTag->getXml())
         ->xsl(Core_Entity::factory('Xsl')->getByName(
            Core_Array::get(Core_Page::instance()->libParams, 'addCommentNoticeXsl'))
         )
         ->process();

      $Shop_Controller_Show->addEntity(
         Core::factory('Core_Xml_Entity')
            ->name('message')->value($xsl_result)
      );
   }
}

// В корне выводим из всех групп
/*if (Core_Array::getGet('group') == 'all')
{
   $Shop_Controller_Show->group(FALSE)->groupsMode('none');
}*/

/* Тут код для фильтра по производителям :: выбираем производителей перед выводом */

$oShop = $Shop_Controller_Show->getEntity();
// XML-сущность, к которй будут добавляться производители
$oProducersXmlEntity = Core::factory('Core_Xml_Entity')->name('producers');
// Добавляем XML-сущность контроллеру показа
$Shop_Controller_Show->addEntity($oProducersXmlEntity);
// Список производителей
$oShop_Producers = $oShop->Shop_Producers;
$oShop_Producers->queryBuilder()
   ->select('shop_producers.*')
   ->distinct()
   ->join('shop_items', 'shop_items.shop_producer_id', '=', 'shop_producers.id')
   ->where('shop_items.shop_group_id', '=', $Shop_Controller_Show->group)
   ->where('shop_items.deleted', '=', 0);

$aShop_Producers = $oShop_Producers->findAll();
foreach ($aShop_Producers as $oShop_Producer)
{
// Добавляем производителя потомком XML-сущности
   $oProducersXmlEntity->addEntity(
      $oShop_Producer->clearEntities()
   );
}
$Shop_Controller_Show->groupsProperties(TRUE);

/* Тут код для фильтра по производителям :: выбираем производителей перед выводом :: конец */
if(isset($_REQUEST['table'])) {$xslName = 'МагазинКаталогТоваровТаблица';}
$Shop_Controller_Show
   ->xsl(
      Core_Entity::factory('Xsl')->getByName($xslName)
   )
   ->itemsProperties(TRUE)
   ->show();


Выдает следующие ошибки


Exception: Wrong Xsl object "Core_Controller".
36 modules/core/exception.php
164 modules/core/controller.php
14 hostcmsfiles/lib/lib_10/lib_10.php
271 modules/lib/model.php
166 modules/core/page.php
4 templates/template20/template.htm
96 modules/template/model.php
166 modules/core/page.php
381 templates/template18/template.htm
96 modules/template/model.php
166 modules/core/page.php
511 modules/core/command/controller/default.php
195 modules/core/router/route.php
239 index.php


Как их можно поправить?

И вообще странно как то. До этого все работало, зашел заголовок поправить, сохранил, и все, привет
#
Re: Вывод каталога товаров на главную.
Ошибки говорит что не найден указанный xsl шаблон.  Заголовок чего именно вы изменили?
«Не выходи из комнаты, не совершай ошибку…»
#
Re: Вывод каталога товаров на главную.
Зашел в "Редактирование узла структуры "Главная""
SEO тут поменял 3 поля. Сохранил. и все
Пропала главная, пошли ошибки
#
Re: Вывод каталога товаров на главную.
а, все!
Получилось вернуть!
Нужно было заполнить

XSL каталога
XSL товара

Почему то  слетели
#
Re: Вывод каталога товаров на главную.
У вас на главной магазин используется? В стеке ошибок hostcmsfiles/lib/lib_10/lib_10.php  , стандартно это вообще ТДС сравнения товаров. Можете предоставить скриншот с страницы редактирования узла структуры "Главная"?
«Не выходи из комнаты, не совершай ошибку…»
#
Re: Вывод каталога товаров на главную.


А подскажите, как под каталогом, добавить произвольный текст?
Модератор
#
Re: Вывод каталога товаров на главную.
GreatAlf,
что вы имеете ввиду "под каталогом"?
#
Re: Вывод каталога товаров на главную.
hostcms писал(а):
что вы имеете ввиду "под каталогом"?


Вот смотрите,

Как между "Каталог продукции" и "Мы рекомендуем" добавить произвольный текст?
Скрин как реализована главная выше.
#
Re: Вывод каталога товаров на главную.
А все, тоже нашел. В Макете "Для главной страницы"
#
Re: Вывод каталога товаров на главную.
GreatAlf,
https://www.hostcms.ru/documentation/modules/shop/add/
Попробуйте добавить Ваш желаемый текст в:
Описание интернет-магазина - Текстовое описание интернет-магазина, отображается в клиентском разделе при входе в магазин.
И отобразить в XSL каталога
E-mail: info@syrbek.ru / телега: @syrbek /skype: activexm / syrbek.ru / Поддержка сайтов / г. Москва [HTML, CSS (Bootstrap), JS(JQuery, ExtJS), PHP, MySQL, MSSql, Posgres, Git, SVN, Redmine]
Авторизация