Skip to content
ms3Favorites
ms3Favorites
Списки избранного для MiniShop3 и других ресурсов — хранение в браузере, синхронизация в БД
  1. Компоненты
  2. ms3Favorites
  3. Сниппеты
  4. ms3FavoritesPopularity

Сниппет ms3FavoritesPopularity

Показывает, сколько пользователей добавили ресурс в избранное (например: «У 12 пользователей в избранном»).

Параметры

ПараметрОписаниеПо умолчанию
resource_idID ресурса (обязательный)
resource_typeТип ресурсов: products, resourcesproducts
tplЧанк для вывода. Плейсхолдеры: [[+count]], [[+resource_id]], [[+text]]. Пусто — только число
minCountНе выводить, если count < minCount0

Плейсхолдеры в чанке

ПлейсхолдерОписание
[[+count]]Количество пользователей
[[+resource_id]]ID ресурса
[[+text]]Текст из лексикона (ms3favorites_popularity)

Примеры

В карточке товара:

modx
<span class="ms3f__popularity">[[!ms3FavoritesPopularity? &resource_id=`[[+id]]`]]</span>
fenom
<span class="ms3f__popularity">{'!ms3FavoritesPopularity' | snippet : ['resource_id' => $id]}</span>

С минимальным порогом (не показывать, если меньше 2):

modx
[[!ms3FavoritesPopularity?
  &resource_id=`[[+id]]`
  &minCount=`2`
]]
fenom
{'!ms3FavoritesPopularity' | snippet : [
  'resource_id' => $id,
  'minCount' => 2
]}

С кастомным чанком:

modx
[[!ms3FavoritesPopularity?
  &resource_id=`[[+id]]`
  &tpl=`tplPopularityBadge`
]]
fenom
{'!ms3FavoritesPopularity' | snippet : [
  'resource_id' => $id,
  'tpl' => 'tplPopularityBadge'
]}

Клиентская загрузка (connector action get_popularity):

javascript
fetch(connectorUrl, {
  method: 'POST',
  body: new URLSearchParams({ action: 'get_popularity', ids: '1,2,3', resource_type: 'products' })
}).then(r => r.json()).then(counts => { /* {1: 5, 2: 12, 3: 0} */ });