Skip to content
mxQuickView
Быстрый просмотр карточки товара и любых ресурсов по AJAX для MODX 3
  1. Компоненты
  2. mxQuickView
  3. Интеграция на сайте

Интеграция на сайт

Документ для менеджера и разработчика: как подключить mxQuickView и использовать в каталоге.

1. Подключение ресурсов (обязательно)

Сначала подключите mxQuickView.initialize один раз в шаблоне.

modx
[[!mxQuickView.initialize]]
fenom
{'!mxQuickView.initialize'|snippet}

Пример с параметрами

modx
[[!mxQuickView.initialize?
  &modalSize=`modal-xl`
  &mouseoverDelay=`350`
]]
fenom
{'!mxQuickView.initialize'|snippet:[
  'modalSize' => 'modal-xl',
  'mouseoverDelay' => 350
]}

Выбор библиотеки модалки

native

modx
[[!mxQuickView.initialize?
  &modalLibrary=`native`
]]
fenom
{'!mxQuickView.initialize'|snippet:[
  'modalLibrary' => 'native'
]}

fancybox

modx
[[!mxQuickView.initialize?
  &modalLibrary=`fancybox`
]]
fenom
{'!mxQuickView.initialize'|snippet:[
  'modalLibrary' => 'fancybox'
]}

bootstrap

modx
[[!mxQuickView.initialize?
  &modalLibrary=`bootstrap`
]]
fenom
{'!mxQuickView.initialize'|snippet:[
  'modalLibrary' => 'bootstrap'
]}

fancybox использует window.Fancybox.show(). В поставке mxQuickView локальные Fancybox-файлы уже включены:

  • assets/components/mxquickview/vendor/fancybox/fancybox.css
  • assets/components/mxquickview/vendor/fancybox/fancybox.umd.js

Для modalLibrary=bootstrap также включены локальные файлы:

  • assets/components/mxquickview/vendor/bootstrap/bootstrap.min.css
  • assets/components/mxquickview/vendor/bootstrap/bootstrap.min.js

Если локальные файлы недоступны, подключается CDN (для Fancybox — @fancyapps/ui, для Bootstrap — bootstrap).

При необходимости можно явно задать пути:

modx
[[!mxQuickView.initialize?
  &modalLibrary=`fancybox`
  &fancyboxCss=`/assets/components/mxquickview/vendor/fancybox/fancybox.css`
  &fancyboxJs=`/assets/components/mxquickview/vendor/fancybox/fancybox.umd.js`
]]
fenom
{'!mxQuickView.initialize'|snippet:[
  'modalLibrary' => 'fancybox',
  'fancyboxCss' => '/assets/components/mxquickview/vendor/fancybox/fancybox.css',
  'fancyboxJs' => '/assets/components/mxquickview/vendor/fancybox/fancybox.umd.js'
]}

2. Быстрый просмотр любого ресурса (новости, статьи, страницы)

Чанк mxqv_resource — универсальный для любых ресурсов (pagetitle, introtext, content). Добавьте в mxquickview_allowed_chunk.

modx
<button type="button"
  data-mxqv-click
  data-mxqv-mode="modal"
  data-mxqv-action="chunk"
  data-mxqv-element="mxqv_resource"
  data-mxqv-id="[[+id]]"
  data-mxqv-title="[[+pagetitle]]">
  Быстрый просмотр
</button>
fenom
<button type="button"
  data-mxqv-click
  data-mxqv-mode="modal"
  data-mxqv-action="chunk"
  data-mxqv-element="mxqv_resource"
  data-mxqv-id="{$id}"
  data-mxqv-title="{$pagetitle}">
  Быстрый просмотр
</button>

3. Кнопка mxQuickView в карточке товара (modal + chunk)

modx
<button type="button"
  data-mxqv-click
  data-mxqv-mode="modal"
  data-mxqv-action="chunk"
  data-mxqv-element="mxqv_product"
  data-mxqv-id="[[+id]]"
  data-mxqv-title="[[+pagetitle]]">
  Быстрый просмотр
</button>
fenom
<button type="button"
  data-mxqv-click
  data-mxqv-mode="modal"
  data-mxqv-action="chunk"
  data-mxqv-element="mxqv_product"
  data-mxqv-id="{$id}"
  data-mxqv-title="{$pagetitle}">
  Быстрый просмотр
</button>

4. Клик + modal + snippet (пример с msCart и широкой модалкой)

modx
[[!mxQuickView.initialize?
  &modalSize=`modal-xl`
]]

<button type="button"
  data-mxqv-click
  data-mxqv-mode="modal"
  data-mxqv-action="snippet"
  data-mxqv-element="msCart"
  data-mxqv-id="[[+id]]"
  data-mxqv-title="[[+pagetitle]]">
  Быстрый просмотр корзины
</button>
fenom
{'!mxQuickView.initialize'|snippet:[
  'modalSize' => 'modal-xl'
]}

<button type="button"
  data-mxqv-click
  data-mxqv-mode="modal"
  data-mxqv-action="snippet"
  data-mxqv-element="msCart"
  data-mxqv-id="{$id}"
  data-mxqv-title="{$pagetitle}">
  Быстрый просмотр корзины
</button>

Требование: msCart должен быть добавлен в mxquickview_allowed_snippet.

Примечание по MiniShop3: компактная миникорзина в quick view рендерится по схеме msCart + tpl.msMiniCart (по docs.modx.pro). data-mxqv-element="msMiniCart" поддерживается как alias.

5. Рендер по наведению (mouseover)

modx
<a href="#"
  data-mxqv-mouseover
  data-mxqv-mode="modal"
  data-mxqv-action="chunk"
  data-mxqv-element="mxqv_product"
  data-mxqv-id="[[+id]]"
  data-mxqv-title="[[+pagetitle]]">Наведите</a>
fenom
<a href="#"
  data-mxqv-mouseover
  data-mxqv-mode="modal"
  data-mxqv-action="chunk"
  data-mxqv-element="mxqv_product"
  data-mxqv-id="{$id}"
  data-mxqv-title="{$pagetitle}">Наведите</a>

Задержка берётся из mxquickview_mouseover_delay или параметра mouseoverDelay у initialize.

6. Режим selector (свой контейнер)

modx
<button type="button"
  data-mxqv-click
  data-mxqv-mode="selector"
  data-mxqv-action="chunk"
  data-mxqv-element="mxqv_product"
  data-mxqv-id="[[+id]]"
  data-mxqv-output=".quickview-output">
  Загрузить в блок
</button>

<div class="quickview-output"></div>
fenom
<button type="button"
  data-mxqv-click
  data-mxqv-mode="selector"
  data-mxqv-action="chunk"
  data-mxqv-element="mxqv_product"
  data-mxqv-id="{$id}"
  data-mxqv-output=".quickview-output">
  Загрузить в блок
</button>

<div class="quickview-output"></div>

7. Комбинированный сценарий: mouseover + selector

modx
<a href="#"
  data-mxqv-mouseover
  data-mxqv-mode="selector"
  data-mxqv-action="chunk"
  data-mxqv-element="mxqv_product"
  data-mxqv-id="[[+id]]"
  data-mxqv-output=".quickview-output">
  Наведите для загрузки
</a>

<div class="quickview-output"></div>
fenom
<a href="#"
  data-mxqv-mouseover
  data-mxqv-mode="selector"
  data-mxqv-action="chunk"
  data-mxqv-element="mxqv_product"
  data-mxqv-id="{$id}"
  data-mxqv-output=".quickview-output">
  Наведите для загрузки
</a>

<div class="quickview-output"></div>

Задержка берётся из mxquickview_mouseover_delay или параметра mouseoverDelay у initialize.

Вариант с Bootstrap 5 modal через selector

modx
<button type="button"
  data-bs-toggle="modal"
  data-bs-target="#qvBootstrapModal"
  data-mxqv-click
  data-mxqv-mode="selector"
  data-mxqv-action="chunk"
  data-mxqv-element="mxqv_product"
  data-mxqv-id="[[+id]]"
  data-mxqv-output="#qvBootstrapModal .modal-body">
  Быстрый просмотр
</button>

<div class="modal fade" id="qvBootstrapModal" tabindex="-1" aria-hidden="true">
  <div class="modal-dialog modal-lg">
    <div class="modal-content">
      <div class="modal-header">
        <h5 class="modal-title">Быстрый просмотр</h5>
        <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
      </div>
      <div class="modal-body"></div>
    </div>
  </div>
</div>
fenom
<button type="button"
  data-bs-toggle="modal"
  data-bs-target="#qvBootstrapModal"
  data-mxqv-click
  data-mxqv-mode="selector"
  data-mxqv-action="chunk"
  data-mxqv-element="mxqv_product"
  data-mxqv-id="{$id}"
  data-mxqv-output="#qvBootstrapModal .modal-body">
  Быстрый просмотр
</button>

<div class="modal fade" id="qvBootstrapModal" tabindex="-1" aria-hidden="true">
  <div class="modal-dialog modal-lg">
    <div class="modal-content">
      <div class="modal-header">
        <h5 class="modal-title">Быстрый просмотр</h5>
        <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
      </div>
      <div class="modal-body"></div>
    </div>
  </div>
</div>
modx
<div data-mxqv-parent data-mxqv-loop="true">
  <button type="button"
    data-mxqv-click
    data-mxqv-mode="modal"
    data-mxqv-action="chunk"
    data-mxqv-element="mxqv_product"
    data-mxqv-id="[[+id]]"
    data-mxqv-title="[[+pagetitle]]">
    Быстрый просмотр
  </button>
</div>
fenom
<div data-mxqv-parent data-mxqv-loop="true">
  <button type="button"
    data-mxqv-click
    data-mxqv-mode="modal"
    data-mxqv-action="chunk"
    data-mxqv-element="mxqv_product"
    data-mxqv-id="{$id}"
    data-mxqv-title="{$pagetitle}">
    Быстрый просмотр
  </button>
</div>

Требование: у каждого триггера внутри должны быть свои data-mxqv-action, data-mxqv-element, data-mxqv-id.

9. Интеграция с MiniShop3 и ms3Variants

  • В quick view-чанке используйте форму ms3-add-to-cart (data-ms3-form, ms3_action=cart/add).
  • После загрузки контента компонент вызывает ms3.productCardUI.reinit() (если MiniShop3 доступен).
  • При установленном ms3Variants доступны плейсхолдеры [[+variants_html]], [[+variants_json]], [[+has_variants]].

Что делает mxQuickView на сервере

  1. Для msProduct вызывается msProductVariants с параметрами productId, product_id, id.
  2. В чанк передаётся [[+has_variants]] как строка true|false.
  3. В чанк передаётся [[+variants_html]] как HTML выбора варианта от msProductVariants.
  4. В чанк передаётся [[+variants_json]] как JSON массива вариантов (id, price, old_price, sku, count, file_id, options).

Что должно быть в quick view-чанке

modx
<div class="qv-product"
  data-mxqv-variants="[[+has_variants]]"
  data-mxqv-variants-json="[[+variants_json:htmlent]]">
  <form method="post" class="ms3_form ms3-add-to-cart qv-product__form" data-ms3-form data-cart-state="add">
    <input type="hidden" name="id" value="[[+id]]">
    <input type="hidden" name="count" value="1">
    <input type="hidden" name="options" value="[]">
    <input type="hidden" name="ms3_action" value="cart/add">
    <div class="qv-product__variants">[[+variants_html]]</div>
    <button type="submit" class="qv-product__btn-cart">В корзину</button>
  </form>
</div>
fenom
<div class="qv-product"
  data-mxqv-variants="{$has_variants}"
  data-mxqv-variants-json="{$variants_json|escape:'html'}">
  <form method="post" class="ms3_form ms3-add-to-cart qv-product__form" data-ms3-form data-cart-state="add">
    <input type="hidden" name="id" value="{$id}">
    <input type="hidden" name="count" value="1">
    <input type="hidden" name="options" value="[]">
    <input type="hidden" name="ms3_action" value="cart/add">
    <div class="qv-product__variants">{$variants_html}</div>
    <button type="submit" class="qv-product__btn-cart">В корзину</button>
  </form>
</div>

Что делает frontend-логика mxQuickView

  1. Ищет .qv-product[data-mxqv-variants] и проверяет флаг (true|1|yes|on).
  2. Парсит data-mxqv-variants-json.
  3. Слушает выбор варианта в .qv-product__variants.
  4. Поддерживает клик по элементам с data-variant-id.
  5. Поддерживает change для select/input, если id варианта передан в value или data-variant-id.
  6. При смене варианта обновляет цену ([data-mxqv-price]), old price (.qv-product__price-old) и изображение (.qv-product__thumb, если есть data-thumb|data-image).

Как это должно работать в UX

  1. Открыли quick view товара с вариантами.
  2. Виден блок выбора [[+variants_html]].
  3. При выборе варианта цена/old price/изображение в модалке меняются без перезагрузки.
  4. Кнопка В корзину отправляет форму ms3 с выбранным вариантом/опциями.

Важно по документации MiniShop3/ms3Variants

10. Частые причины, почему блок не работает

  1. Не подключен mxQuickView.initialize.
  2. Элемент не добавлен в whitelist (allowed_chunk, allowed_snippet, allowed_template).
  3. Не передан или неверный data-mxqv-id.
  4. Для selector-режима отсутствует целевой контейнер data-mxqv-output.
  5. Ресурс недоступен для просмотра (ответ Access denied).