
ms3ProductSets
Динамические подборки товаров для MiniShop3


{'mspsLexiconScript' | snippet}
<link rel="stylesheet" href="{'assets_url' | option}components/ms3productsets/css/productsets.css">
<script src="{'assets_url' | option}components/ms3productsets/js/productsets.js"></script>[[!mspsLexiconScript]]
<link rel="stylesheet" href="[[++assets_url]]components/ms3productsets/css/productsets.css">
<script src="[[++assets_url]]components/ms3productsets/js/productsets.js"></script>{set $msps_buy_together = 'ms3ProductSets' | snippet : [
'type' => 'buy_together',
'resource_id' => $_modx->resource.id,
'max_items' => 6,
'tpl' => 'tplSetItem'
]}
{if $msps_buy_together}
<section class="product-set">
<h2>С этим товаром покупают</h2>
{$msps_buy_together}
</section>
{/if}[[!ms3ProductSets?
&type=`buy_together`
&resource_id=`[[*id]]`
&max_items=`6`
&tpl=`tplSetItem`
&toPlaceholder=`msps_buy_together`
]]
[[+msps_buy_together:notempty=`
<section class="product-set">
<h2>С этим товаром покупают</h2>
[[+msps_buy_together]]
</section>
`]]{'ms3ProductSets' | snippet : [
'type' => 'auto',
'category_id' => 5,
'resource_id' => 0,
'max_items' => 8,
'tpl' => 'tplSetItem'
]}[[!ms3ProductSets?
&type=`auto`
&category_id=`5`
&resource_id=`0`
&max_items=`8`
&tpl=`tplSetItem`
]]ms3productsets.vip_set_1.{'ms3ProductSets' | snippet : [
'type' => 'vip',
'set_id' => 1,
'max_items' => 6,
'tpl' => 'tplSetVIP'
]}[[!ms3ProductSets?
&type=`vip`
&set_id=`1`
&max_items=`6`
&tpl=`tplSetVIP`
]]По умолчанию блок скрывается, если подборка пустая.
{'ms3ProductSets' | snippet : [
'type' => 'similar',
'resource_id' => $_modx->resource.id,
'hideIfEmpty' => 0,
'emptyTpl' => 'tplSetEmpty'
]}[[!ms3ProductSets?
&type=`similar`
&resource_id=`[[*id]]`
&hideIfEmpty=`0`
&emptyTpl=`tplSetEmpty`
]]<div id="msps-auto"></div>
<script>
document.addEventListener('DOMContentLoaded', function () {
if (window.ms3ProductSets) {
window.ms3ProductSets.render('#msps-auto', {
type: 'auto',
category_id: 5,
max_items: 8,
tpl: 'tplSetItem'
});
}
});
</script><button type="button" data-add-to-cart="{$id}" data-count="1">В корзину</button><button type="button" data-add-to-cart="[[+id]]" data-count="1">В корзину</button>productsets.js сам отправит запрос в connector.php.
Кнопка с атрибутом data-add-set добавляет все товары подборки в корзину. Используется в чанках tplSetVIP и tplSetWrapper (при count > 0). Контейнер подборки должен содержать элементы с data-product-id (карточки из tplSetItem). JS находит контейнер от кнопки (.msps__vip-set, .msps__wrapper или [data-set-type]) и последовательно вызывает addToCart для каждого товара.
<button type="button" class="msps__add-all-button" data-add-set="1">
{$_modx->lexicon('msproductsets_add_all_to_cart')}
</button><button type="button" class="msps__add-all-button" data-add-set="1">
[[%msproductsets_add_all_to_cart]]
</button>mspsLexiconScript, productsets.css, productsets.js.ms3ProductSets вызывается с корректным resource_id или category_id.vip заполнен vip_set_1 или ручные связи в таблице.