Плоское меню из категорий товаров

Возникла задачка: выбрать все категории товаров и вывести их списком в одном месте. Этакое "плоское меню". 6 блоков, по 2 категории в каждом, итого 12 небольших меню. При этом, конечно, категории товаров находятся на разной глубине, и даже вложены друг в друга.
Ни один стандартный сниппет так не сделает, поэтому пришлось написать свой.

<?php
if (!isset($group)) {$group = 2;} // Сколько меню в одном блоке
if (!isset($cat_limit)) {$cat_limit = 12;} // Сколько выбирать категорий
if (!isset($product_limit)) {$product_limit = 5;} // Сколько выбирать категорий
if (!isset($cat_sort)) {$cat_sort = 'RAND()';} // Сортировка категорий
if (!isset($product_sort)) {$product_sort = 'RAND()';} // Сортировка товаров
if (!isset($showEmptyCat)) {$showEmptyCat = 1;} // Выводить ли пустые категории
if (!isset($showUnpublished)) {$showUnpublished = 0;} // Выводить неопубликованные
if (!isset($showDeleted)) {$showDeleted = 0;} // Выводить удаленные
if (empty($tplOuter)) {$tplOuter = '@INLINE <div class="span2">[[+menus]]</div>';} // Чанк-обертка блока с несколькими меню
if (empty($tplMenu)) {$tplMenu = '@INLINE <ul class="unstyled">[[+rows]]</ul>';} // Чанк для одного меню
if (empty($tplCat)) {$tplCat = '@INLINE <li class="footer-title"><a href="/[[+uri]]">[[+pagetitle]]</a></li>';} // Чанк категории
if (empty($tplRow)) {$tplRow = '@INLINE <li><a href="/[[+uri]]">[[+pagetitle]]</a></li>';} // Чанк товара
if (empty($tplCatActive)) {$tplCatActive = '@INLINE <li class="footer-title"><span>[[+pagetitle]]</span></li>';} // Текущая категория
if (empty($tplRowActive)) {$tplRowActive = '@INLINE <li><span>[[+pagetitle]]</span></li>';} // Текущий товар
//---
$pdo = $modx->getService('pdoFetch');
$pdo->setConfig($scriptProperties);

$cats = $pdo->getCollection('modResource', array('class_key' => 'msCategory'), array(
    'limit' => $cat_limit,
    'showUnpublished' => $showUnpublished,
    'showDeleted' => $showDeleted,
    'sortby' => $cat_sort,
));
if (empty($cats)) {return '';}

$i = 0;
$menus = $output = '';
foreach ($cats as $cat) {
    $children = $pdo->getCollection('modResource', array('class_key' => 'msProduct', 'parent' => $cat['id']), array(
        'limit' => $product_limit,
        'showUnpublished' => $showUnpublished,
        'showDeleted' => $showDeleted,
        'sortby' => $product_sort,
    ));

    if (empty($children) && empty($showEmptyCat)) {
        continue;
    }

    $rows = $cat['id'] == $modx->resource->id
        ? $pdo->getChunk($tplCatActive, $cat)
        : $pdo->getChunk($tplCat, $cat);

    if (!empty($children)) {
        foreach ($children as $row) {
            $rows .= $row['id'] == $modx->resource->id
                ? $pdo->getChunk($tplRowActive, $row)
                : $pdo->getChunk($tplRow, $row);
        }
    }

    $menus .= $pdo->getChunk($tplMenu, array('rows' => $rows));

    if ($i % $group) {
        $output .= $pdo->getChunk($tplOuter, array('menus' => $menus));
        $menus = '';
    }
    $i++;
}

return $output;
Сниппет выбирает 12 категорий и по 5 товаров к ним. Затем собирает все в кучу, оформляет и выводит. Всего выходит не больше 13 запросов в БД.
Вот, что получилось на реальном проекте:

Комментарии

bezumkin.ru
Личный сайт Василия Наумкина
Прямой эфир
Александр Наумов
23.07.2024, 00:20:37
Василий, спасибо большое!!
Василий Наумкин
01.07.2024, 11:56:41
Да, верно, именно так. А в контроллере, скорее всего, ловить данные методом post.
Василий Наумкин
26.06.2024, 09:38:15
О, точно, вылезает если не залогинен. Спасибо, исправил!
Василий Наумкин
09.04.2024, 04:45:01
> Ошибка 500 Это не похоже на ошибку Nginx, это скорее всего ошибка PHP - надо смотреть его логи. ...
Василий Наумкин
20.03.2024, 21:21:52
Volledig!
Андрей
14.03.2024, 13:47:10
Василий! Как всегда очень круто! Моё почтение!
russel gal
09.03.2024, 20:17:18
> А этот стоило написать хотя бы затем, чтобы получить комментарий от юзера, который ничего не писал...
Александр Наумов
27.01.2024, 03:06:18
Василий, спасибо! Извини, тупанул.
Василий Наумкин
22.01.2024, 07:43:20
Давай-давай!
Василий Наумкин
24.12.2023, 14:26:13
Спасибо!