18 апр21:28
Генерация YML в MODx Revolution и Minishop2
Теги: Modx, minishop2, Интернет магазин
Просмотров: 5668
Время прочтения: 5 минут.
Навигация по статье:
YML файл необходим для синхронизации интернет магазина с Яндекс Маркетом и для включения турбо-страниц в Яндекс Вебмастере.
По ссылке, Вы сможете подробно ознакомиться с YML (Yandex Market Language) форматом.
Первым шагом создадим ресурс с пустым шаблоном и назовем его YML, ставим галочку опубликован, не отображать в меню. На вкладке настройки - устанавливаем тип содержимого XML
и убираем галочку использовать html-редактор.
В содержимое ресурса вставляем следующий код:
<?xml version="1.0" encoding="UTF-8"?> <yml_catalog date="[[!printDate]]" > <shop> <name>[[++site_name]]</name> <company>[[++site_name]]</company> <url>[[++site_url]]</url> <currencies> <currency id="RUR" rate="1"/> </currencies> <categories> [[pdoResources? &parents=`0` &depth=`10` &limit=`10000` &tpl=`ymlCategoriesTpl` &where=`{"class_key":"msCategory"}` &showUnpublished=`1`]] </categories> <offers> [[msProducts? &templates=`5` &depth=`10` &limit=`10000` &parents=`2` &tpl=`ymlOfferTpl` &includeContent=`1`]] </offers> </shop> </yml_catalog>
Где templates
- шаблон товара, а parents
- id ресурса корневого каталога.
Создаем чанк ymlCategoriesTpl
.
<category id="[[+id]]" [[+parent:isnot=`2`:then=`parentId="[[+parent]]"`]]>[[+pagetitle]]</category>
Где parent id - id корневого ресурса каталога.
3. Создаем чанк ymlOfferTpl
.
Для того, чтобы поменять размер миниатюр изображений до приемлемого, способствующего быстрой загрузки турбо страниц, идем в Медиа -> Источники файлов -> MS2 Images, и создаем новый размер для миниатюр товаров минишопа, я назвал этот размер yml. Затем в чанке ymlOfferTpl
указываем именно его в picture
. Но на этом еще не все. Ищем дефолтный сниппет msProducts
и меняем параметр includeThumbs
– список превьюшек, указав в него наш новый размер yml. Сохраняем набор параметров, сохраняем сниппет. Теперь нам необходимо сгенерировать превьюшки yml. О том, как сделать это быстро, массово, для всех товаров, я рассказывал в этой статье. После генерации проверяем, открыв наш ресурс yml, и убеждаемся, что сгенерированные изображения открываются.
<offer id="[[+id]]" available="true"> <url>[[~[[+id]]? &scheme=`full`]]</url> <price>[[+price:stripString=` `]]</price> [[+old_price:isnot=`0`:then=`<oldprice>[[+old_price:stripString=` `]]</oldprice>`]] <currencyId>RUR</currencyId> <categoryId>[[+parent]]</categoryId> <delivery-options> <option cost="300" days="2-5"/> </delivery-options> [[-<typePrefix>[[#[[+parent]].pagetitle:htmlent]]</typePrefix>]] <description>[[+introtext:htmlent]]</description> <vendorCode>[[+article]]</vendorCode> [[-<local_delivery_cost>0</local_delivery_cost>]] <manufacturer_warranty>true</manufacturer_warranty> <picture>http://site.ru[[+yml]]</picture> <name>[[+pagetitle]]</name> [[!printOptions?&tpl=`printOptionsTpl`&res_id=`[[+id]]`]] </offer>
Для вывода опций, которые хранятся в таблицах modx_ms2_product_options
, modx_ms2_options
, мы создадим сниппет printOptions
:
if(empty($tpl) || !$modx->getChunk($tpl)){ return false; } $sQuery = "SELECT po.value as value, o.caption as name FROM ". $modx->getOption('table_prefix') ."ms2_product_options po LEFT JOIN ". $modx->getOption('table_prefix') ."ms2_options o ON (po.key = o.key) WHERE po.product_id = '".$res_id."'"; $result = $modx->query($sQuery); $res = $result->fetchAll(PDO::FETCH_ASSOC); $output = ""; foreach($res as $v){ $output .= $modx->getChunk($tpl,$v); } echo $output;
Для вывода опций в файл YML, создадим чанк printOptionsTpl
:
<param name="[[+name]]">[[+value]]</param>Использовать будем так:
[[!printOptions?&tpl=`printOptionsTpl`&res_id=`[[+id]]`]]
Для вывода ткущей даты и времени будем использовать сниппет printDate
return date("Y-m-d H:i");
На этом все, ссылка на данный файл https://site.ru/yml.xml