
ms3Favorites
Списки избранного для MiniShop3 и других ресурсов — хранение в браузере, синхронизация в БД


Показывает, сколько пользователей добавили ресурс в избранное (например: «У 12 пользователей в избранном»).
| Параметр | Описание | По умолчанию |
|---|---|---|
| resource_id | ID ресурса (обязательный) | — |
| resource_type | Тип ресурсов: products, resources | products |
| tpl | Чанк для вывода. Плейсхолдеры: [[+count]], [[+resource_id]], [[+text]]. Пусто — только число | — |
| minCount | Не выводить, если count < minCount | 0 |
| Плейсхолдер | Описание |
|---|---|
[[+count]] | Количество пользователей |
[[+resource_id]] | ID ресурса |
[[+text]] | Текст из лексикона (ms3favorites_popularity) |
В карточке товара:
<span class="ms3f__popularity">[[!ms3FavoritesPopularity? &resource_id=`[[+id]]`]]</span><span class="ms3f__popularity">{'!ms3FavoritesPopularity' | snippet : ['resource_id' => $id]}</span>С минимальным порогом (не показывать, если меньше 2):
[[!ms3FavoritesPopularity?
&resource_id=`[[+id]]`
&minCount=`2`
]]{'!ms3FavoritesPopularity' | snippet : [
'resource_id' => $id,
'minCount' => 2
]}С кастомным чанком:
[[!ms3FavoritesPopularity?
&resource_id=`[[+id]]`
&tpl=`tplPopularityBadge`
]]{'!ms3FavoritesPopularity' | snippet : [
'resource_id' => $id,
'tpl' => 'tplPopularityBadge'
]}Клиентская загрузка (connector action get_popularity):
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} */ });