Skip to content
ms3ProductSets
ms3ProductSets
Динамические подборки товаров для MiniShop3 — ручные связи, авто-рекомендации, админка шаблонов
  1. Компоненты
  2. ms3ProductSets
  3. Для разработчика

API и интерфейсы

Сниппет ms3ProductSets

Ключевые параметры

ПараметрПо умолчаниюОписание
typebuy_togetherТип подборки
resource_id / productIdтекущий ресурсID базового товара
max_itemsms3productsets.max_itemsЛимит (1..100)
category_id0Категория для авто-подбора
set_id0Номер VIP-набора (для type=vip). При 0 или не заданном используется 1 — настройка ms3productsets.vip_set_1.
tpltplSetItemЧанк карточки
emptyTpltplSetEmptyЧанк для пустого результата
hideIfEmptytruetrue -> пустая строка, false -> emptyTpl
exclude_ids''Исключаемые ID
tplWrapper''Обёртка с плейсхолдерами output, type, count
sortby / sortdir'' / ASCЕсли sortby пуст, сохраняется порядок подборки
showUnpublishedfalseПроброс в msProducts
showHiddenfalseПроброс в msProducts
includeTVs, includeThumbs, tvPrefix''Проброс в msProducts
returndatadata, ids, json
toPlaceholder''Запись результата в placeholder

Поддерживаемые type

auto, vip, cross-sell, popcorn, also-bought, buy_together, similar, cart_suggestion, auto_sales, custom.

Подробная логика каждого типа — в Типы подборок.

Примеры вызова

fenom
{'ms3ProductSets' | snippet : [
  'type' => 'similar',
  'resource_id' => $_modx->resource.id,
  'max_items' => 6,
  'tpl' => 'tplSetItem'
]}
modx
[[!ms3ProductSets?
  &type=`similar`
  &resource_id=`[[*id]]`
  &max_items=`6`
  &tpl=`tplSetItem`
]]

Сниппет mspsLexiconScript

Выводит:

  • window.mspsLexicon (ключи для фронтовых сообщений);
  • window.mspsConfig (maxItems, lang).

Подключать перед productsets.js.

Fenom: {'mspsLexiconScript' | snippet}MODX: [[!mspsLexiconScript]]

Коннектор assets/components/ms3productsets/connector.php

Front (web)

actionМетодПараметрыОтвет
get_setPOSTtype, resource_id, category_id, set_id, max_items, tpl, emptyTpl, hideIfEmptyHTML
add_to_cartPOSTproduct_id, countJSON {success,message}

Manager (mgr, авторизация обязательна)

actionНазначениеОсновные параметры
get_templatesСписок шаблонов подборок
save_templateСоздать/обновить шаблонid, name, type, related_product_ids, sortorder
delete_templateУдалить шаблонid
apply_templateПрименить шаблон к категориям/товарамtemplate_id, parent_id или parent_ids[], replace
unbind_templateОтвязать шаблон от категорииtemplate_id, parent_id или parent_ids[]
get_resource_treeДерево категорий (без товаров)parent_id, context_key
get_resourcesСписок товаров для пикераparent_id, template_id, query, limit

JS API (window.ms3ProductSets)

МетодНазначение
render(selector, options)Рендер блока подборки через action=get_set
addToCart(productId, count)Добавление товара в корзину через action=add_to_cart
addAllToCart(buttonOrContainer)Добавление всего набора в корзину. Принимает DOM-элемент (кнопку с data-add-set или контейнер) либо CSS-селектор. Ищет [data-product-id] и [data-add-to-cart] в контейнере, последовательно вызывает addToCart для каждого, затем toast и событие msps:cart:update.
toast(message)Показ frontend-уведомления

События после успешного добавления:

  • addToCart: msps:cart:update с detail: { product_id, count }
  • addAllToCart: msps:cart:update с detail: { product_ids }

Плагины

ПлагинСобытиеНазначение
ms3productsets_sync_tvOnDocFormSaveСинхронизация TV подборок в таблицу ms3_product_sets
ms3productsets_on_resource_deleteOnResourceDeleteОчистка связей удаляемого ресурса