Обработка и вывод данных из YML-файла
Что такое YML
YML-файл содержит данные о товарах: названия, цены, ссылки, изображения, категории и другие параметры. Эти данные можно использовать в письмах — например, чтобы подставлять товары в e-commerce сценариях: Брошенная корзина, Брошенный просмотр и других.
В письмах YML-файл используется как внешний источник данных. Чтобы обратиться к этим данным, файл нужно подключить через Модуль Продажи, а в шаблоне письма загрузить его и получить нужную информацию с помощью функций шаблонизатора.
Все поля товаров (name, price, picture, param и другие) формируются на основе структуры YML-файла.
Дополнительные разделы в YML-файле
Как подключить YML-файл
Перед использованием в письме данных из YML-файла, его нужно подключить через Модуль Продажи.
После подключения к информации из файла можно обращаться в шаблоне письма. Загрузка данных происходит в момент формирования письм а, поэтому URL файла может быть динамическим.
Данные из YML-файла можно использовать при всех способах отправки писем, включая отправку через Stream-API и SMTP.
Как вывести данные из YML-файла в письме
Для загрузки YML-файла в шаблон письма используйте функцию yml_load():
[% yml = yml_load("URL_YML_ФАЙЛА") %]
Если при загрузке происходит ошибка, по умолчанию письмо отменяется. Это поведение можно изменить с помощью параметра ignore_error — с ним рассылка выйдет, даже если YML-файл недоступен:
[% yml = yml_load("URL_YML_ФАЙЛА", "ignore_error", 1) %]
В этом случае функция вернёт значение undef, а результат нужно обработать вручную.
Получение данных
Функции вида yml_xxx_get() в озвращают объект, если элемент найден, или undef, если нет.
[% offer = yml_offer_get(yml, "ID_ТОВАРА") %]
После этого можно обращаться к свойствам товара:
[% offer.name %]
[% offer.price %]
[% offer.url %]
Функции вида yml_xxx_list() возвращают список всех id элементов указанного типа.
[% offer_ids = yml_offer_list(yml) %]
Затем для каждого id можно получить объект товара через yml_offer_get().
Поле picture в YML-файлах может содержать одно изображ ение или массив изображений. Чтобы корректно вывести изображение, используйте проверку:
[% IF offer.picture[0] %]
[% offer.picture[0] %]
[% ELSE %]
[% offer.picture %]
[% END %]
Вывод данных, собранных для сценариев Модуля Продажи
Брошенная корзина
Вывод товаров, которые находятся в корзине пользователя:
[% yml = yml_load("URL_YML_ФАЙЛА", "ignore_error", 1) %]
[% basket = ssecquery('basket') %]
[% FOREACH item IN basket[0].items %]
[% offer = yml_offer_get(yml, item.product.id) %]
[% NEXT IF offer == undef %]
<a href="[% offer.url %]">
<img src="[% IF offer.picture[0] %][% offer.picture[0] %][% ELSE %][% offer.picture %][% END %]">
</a><br>
<a href="[% offer.url %]">[% offer.name %]</a><br>
Цена: [% offer.price %] руб.<br>
Количество: [% item.product.qnt %] шт<br>
Стоимость: [% offer.price * item.product.qnt %] руб.<br>
[% END %]