цена товара в title

#
Re: цена товара в title
неужели никто не делал?
#
Re: цена товара в title
Никто не поможет?
#
Re: цена товара в title
Замените у себя вот это:


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

   $aTitle[] = $oShop_Item->seo_title != ''
      ? $oShop_Item->seo_title
      : $oShop_Item->name;
  

   $aDescription[] = $oShop_Item->seo_description != ''
      ? $oShop_Item->seo_description
      : $oShop_Item->name;

   $aKeywords[] = $oShop_Item->seo_keywords != ''
      ? $oShop_Item->seo_keywords
      : $oShop_Item->name;
}


На это:

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

   $sItemTitle = $oShop_Item->seo_title != ''
      ? $oShop_Item->seo_title
      : $oShop_Item->name;

   $aTitle[] = $oShop_Item->price . ' - ' . $sItemTitle;

   $aDescription[] = $oShop_Item->seo_description != ''
      ? $oShop_Item->seo_description
      : $oShop_Item->name;

   $aKeywords[] = $oShop_Item->seo_keywords != ''
      ? $oShop_Item->seo_keywords
      : $oShop_Item->name;
}


И цена появится в title. Сразу предостерегу, что не учитываются скидки.
А теперь расскажу почему этого делать не надо.
Пару лет назад мне пришла в голову мысль выводить в title динамические данные. Правда это была не цена, а дата. И всё было хорошо и отлично.
Но ровно до того дня... Дня, когда началась индексация сайта.

После первого захода паучков гугла и яндекса тайтлы с датами начали красоваться на страницах поиска. Ну как и ожидалось. Я был счастлив.
Но потом случилось страшное. Даты мероприятий под влиянием различных причин начали изменятся.
И в тайтле начали изменятся, но только на сайте в тайтле.
А в поиске они подло отображали дату, когда человек опаздает на это мероприятие, ну или прийдёт на недельку-другую раньше.

Гугл конечно достаточно быстро подхватывал новую информацию, а вот яндекс этим не грешил.
И не заходил по паре месяцев...

Да, конечно даты выводятся на многих сайтах/поисковиках и сейчас, но другими способами (я про schema).
И они не так Ярко о себе заявляют в поисковой выдаче как крупная надпись в title страницы.
Email: roman.fov@gmail.com Skype: roman-fov
#
Динамический TITLE
Может кто подскажет, как можно в карточке товара выводить TITLE динамически.
Ну, например, название товара + доп. свойства товара.
<title>{ название товара } {доп. свойство1 товара} {доп. Свойство2 товара}</title>
#
Re: цена товара в title
Либо редактируйте код настроек ТДС магазина либо используйте шаблоны SEO https://www.hostcms.ru/documentation/modules/shop/shop-seo-templates/
«Не выходи из комнаты, не совершай ошибку…»
#
Динамический TITLE товара
Вроде в шаблоне SEO интернет-магазина всё делаю правильно,
но всё равно ничего не выводится. Кто может - помогите!
Код ТДС магазина такой:
<?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)))
   ->tags(true)
   ->comments(true)
   ->associatedItems(true)
   ->modifications(true);
// добавляем окружающие элементы - начало
// Если мы находимся на странице товара
if ($Shop_Controller_Show->item) {
   $oShop_Item = Core_Entity::factory('Shop_Item', $Shop_Controller_Show->item);
// Текущий элемент и текущая группа
   $cur_elem = $Shop_Controller_Show->item;
   $cur_group = $oShop_Item->shop_group_id;
// Выбор из shop_items где shop_items.id < $cur_elem порядок на shop_items.id
   $oCore_QueryBuilder_Select = Core_QueryBuilder::select()
   ->select('shop_items.path','shop_items.name')
   ->from('shop_items')
   ->where('active', '=', 1)
   ->open()
   ->where('shop_items.id','<',$cur_elem)
   ->setAnd()
   ->where('shop_items.shop_group_id','=',$cur_group)
   ->setAnd()
   ->where('shop_items.deleted','=','0')
   ->close()
   ->clearOrderBy()
   ->orderBy('id')
   ->limit(1);
      $prev = $oCore_QueryBuilder_Select->execute()->asAssoc()->current();
      $prev = $prev['path'];
      $prev_name = $oCore_QueryBuilder_Select->execute()->asAssoc()->current();
      $prev_name = $prev_name['name'];
// Выбор из shop_items где shop_items.id > $cur_elem порядок на shop_items.id
   $oCore_QueryBuilder_Select = Core_QueryBuilder::select()
   ->select('shop_items.path','shop_items.name')
   ->from('shop_items')
   ->where('active', '=', 1)
   ->open()
   ->where('shop_items.id','>',$cur_elem)
   ->setAnd()
   ->where('shop_items.shop_group_id','=',$cur_group)
   ->setAnd()
   ->where('shop_items.deleted','=','0')
   ->close()
   ->clearOrderBy()
   ->orderBy('id')
   ->limit(1);
      $next = $oCore_QueryBuilder_Select->execute()->asAssoc()->current();
      $next = $next ['path'];
      $next_name = $oCore_QueryBuilder_Select->execute()->asAssoc()->current();
      $next_name = $next_name['name'];
   $Shop_Controller_Show
   ->addEntity(Core::factory('Core_Xml_Entity')
   ->name('neighboring_items')
   ->addEntity(Core::factory('Core_Xml_Entity')->name('prev_item')->value($prev))
   ->addEntity(Core::factory('Core_Xml_Entity')->name('prev_item_name')->value($prev_name))
   ->addEntity(Core::factory('Core_Xml_Entity')->name('next_item')->value($next))
   ->addEntity(Core::factory('Core_Xml_Entity')->name('next_item_name')->value($next_name))
   );
}
// добавляем окружающие элементы - конец
if ($Shop_Controller_Show->item == 0) {
      $Shop_Controller_Show->itemsForbiddenTags(array('text'));
// В корневой директории выводим из всех подгрупп
/*if ($Shop_Controller_Show->group == 0) {
   $Shop_Controller_Show->group = false;
   $Shop_Controller_Show->shopItems()
   ->queryBuilder()
   ->where('shop_items.modification_id', '=', 0);}*/
// Производители
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);
   $Shop_Controller_Show->addCacheSignature('producer_id=' . $iProducerId);
   }
   if (Core_Array::getGet('filter') || Core_Array::getGet('sorting')) {
   $Shop_Controller_Show->addEntity(Core::factory('Core_Xml_Entity')
   ->name('filter')->value(1));
   $oShop = $Shop_Controller_Show->getEntity();
   $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);
// Цены
   $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_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, $oShop->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(IF(`shop_discounts`.`type` = 0, `shop_discounts`.`value`, 0)) / 100)) * {$currency_coefficient} - SUM(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');
   $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.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')
   ->groupBy('shop_items.id');
   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');
// Дополнительные свойства
$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();
   $aTmpProperties = array();
   $havingCount = 0;
   foreach ($aProperties as $oProperty) {
// Св-во может иметь несколько значений
   $aPropertiesValue = Core_Array::getGet('property_' . $oProperty->id);
   if ($aPropertiesValue) {
      !is_array($aPropertiesValue) && $aPropertiesValue = array($aPropertiesValue);
      $aPropertiesValue = array_map('strval', $aPropertiesValue);
      $aTmpProperties[] = array($oProperty, $aPropertiesValue);
      $havingCount++;
      }
   elseif (!is_null(Core_Array::getGet('property_' . $oProperty->id . '_from'))) {
      $tmpFrom = Core_Array::getGet('property_' . $oProperty->id . '_from');
      $tmpTo = Core_Array::getGet('property_' . $oProperty->id . '_to');
      !is_array($tmpFrom) && $tmpFrom = array($tmpFrom);
      !is_array($tmpTo) && $tmpTo = array($tmpTo);
      // С ... по ...
      foreach ($tmpFrom as $iKey => $sValue) {
         $to = Core_Array::get($tmpTo, $iKey);
         $aTmpProperties[] = array($oProperty, array('from' => $sValue != ''
         ? ($oProperty->type == 11 ? floatval($sValue) : intval($sValue))
         : '',
         'to' => $to != ''
         ? ($oProperty->type == 11 ? floatval($to) : intval($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, $aPropertyValues)) = 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 (!isset($aPropertyValues['from'])) {
// Для строк фильтр LIKE %...%
      if ($oProperty->type == 1) {
      foreach ($aPropertyValues as $propertyValue) {
      $Shop_Controller_Show->shopItems()->queryBuilder()
      ->where($tableName . '.value', 'LIKE', "%{$propertyValue}%");
      }} else {
// Checkbox
   $oProperty->type == 7 && $aPropertyValues[0] != '' && $aPropertyValues = array(1);
   $bCheckUnset = $oProperty->type != 7 && $oProperty->type != 3;
   $bCheckUnset && $Shop_Controller_Show->shopItems()->queryBuilder()->open();
   $Shop_Controller_Show->shopItems()->queryBuilder()
   ->where(
   $tableName . '.value',
   count($aPropertyValues) == 1 ? '=' : 'IN',
   count($aPropertyValues) == 1 ? $aPropertyValues[0] : $aPropertyValues);
   $bCheckUnset && $Shop_Controller_Show->shopItems()->queryBuilder()
   ->setOr()
   ->where($tableName . '.value', 'IS', NULL)
   ->close();
   }
   $Shop_Controller_Show->shopItems()->queryBuilder()
   ->setOr();
   foreach ($aPropertyValues as $propertyValue) {
   $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(Core_Array::get($aPropertyValues, 'from'));
      $from && $Shop_Controller_Show->shopItems()->queryBuilder()
      ->open()
      ->where($tableName . '.value', '>=', $from)
      ->setOr()
      ->where($tableName . '.value', 'IS', NULL)
      ->close()
      ->setAnd();
      $to = trim(Core_Array::get($aPropertyValues, 'to'));
      $to && $Shop_Controller_Show->shopItems()->queryBuilder()
      ->open()
      ->where($tableName . '.value', '<=', $to)
      ->setOr()
      ->where($tableName . '.value', 'IS', NULL)
      ->close();
   $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');
      $havingCount > 1
      && $Shop_Controller_Show->shopItems()->queryBuilder()
      ->having(Core_Querybuilder::expression('COUNT(DISTINCT `shop_item_properties`.`property_id`)'), '=', $havingCount);
      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->phone = Core_Str::stripTags(Core_Array::getPost('phone'));
      $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();
            $oComment
               ->dateFormat($oShop->format_date)
               ->dateTimeFormat($oShop->format_datetime);
            $oShop_Item->add($oComment)->clearCache();
            $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();
            $aFrom = array_map('trim', explode(',', EMAIL_TO));
            Core_Mail::instance()
               ->to(EMAIL_TO)
               ->from($aFrom[0])
               ->header('Reply-To', Core_Valid::email($oComment->email)
                  ? $oComment->email
                  : $aFrom[0]
               )
               ->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));
            $oComment->text = Core_Str::br2nl($oComment->text);
            $Shop_Controller_Show->addEntity($oComment);
         }} else {
         $oXmlCommentTag->addEntity(Core::factory('Core_Xml_Entity')
            ->name('error_time')->value(1));
         $oComment->text = Core_Str::br2nl($oComment->text);
         $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 ($Shop_Controller_Show->group == 0) {
   $Shop_Controller_Show->group(false)->forbidSelectModifications();
   }*/

/* ----------------------  П О К А З  С Х О Ж И Х  Т О В А Р О В  на основе меток  -  начало  */
$oShop_Item = Core_Entity::factory('Shop_Item', $Shop_Controller_Show->item);
$oTag_Shop_Items = $oShop_Item->Tag_Shop_Items->findAll();
// Минимальное количество тегов для совпадения
$iSameTags = 3;
$aTagIds = array();
foreach($oTag_Shop_Items as $oTag_Shop_Item) { $aTagIds[] = $oTag_Shop_Item->tag_id; }
if (count($aTagIds)) {
$oSameTag_Shop_Items = Core_Entity::factory('Tag_Shop_Item');
$oSameTag_Shop_Items->queryBuilder()
->select('tag_shop_items.*')
->where('tag_id', 'IN', $aTagIds)
->where('tag_shop_items.shop_item_id', '!=', $oShop_Item->id)
->join('shop_items', 'tag_shop_items.shop_item_id', '=', 'shop_items.id')
->join('shops', 'shop_items.shop_id', '=', 'shops.id')
->where('shops.site_id', '=', CURRENT_SITE)
->groupBy('shop_items.id')
->having('COUNT(tag_id)', '>=', $iSameTags)
->clearOrderBy()
->orderBy('RAND()')
->limit(4);
$aSameTag_Shop_Items = $oSameTag_Shop_Items->findAll();
$oXmlSamenews = Core::factory('Core_Xml_Entity')->name('samenews');
$Shop_Controller_Show->addEntity($oXmlSamenews);
foreach($aSameTag_Shop_Items as $oSameTag_Shop_Item) {
$oXmlSamenews->addEntity($oSameTag_Shop_Item->Shop_Item->clearEntities());
}}
/* ----------------------  П О К А З  С Х О Ж И Х  Т О В А Р О В  на основе меток  -  конец  */

// Производители
$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();
// Добавляем производителя потомком XML-сущности
foreach ($aShop_Producers as $oShop_Producer) {
   $oProducersXmlEntity->addEntity($oShop_Producer->clearEntities()); }
$Shop_Controller_Show->xsl(Core_Entity::factory('Xsl')->getByName($xslName))
// Выводить свойства товаров
   ->itemsProperties(true)
// Выводить специальные цены
   ->specialprices(true)
// Выводить модификации на уровне с товаром
//->modificationsList(true)
// Режим вывода групп
//->groupsMode('none')
// Выводить доп. св-ва групп
//->groupsProperties(true)
// Фильтровать по ярлыкам
//->filterShortcuts(true)
   ->show();
#
Цена товара в title
Нужно прописать в Интернет-магазине - Шаблоны SEO - Шаблон title (для товара)  
{item.price} {item.currencyName}
#
Цена товара в title
Нужно прописать в Интернет-магазине - Шаблоны SEO - Шаблон title (для товара)  
{item.price} {item.currencyName}
Авторизация