Подсчет и вывод количества потомков ресурса в MODX

Выбрать только ресурсы с потомками в pdoResources

Задача — выбрать только те ресурсы, у которых есть потомки, то есть, к примеру, не пустые категории. А также само количество поменстить в плейсхолдер для вывода в чанке.

Пояснение по сниппету pdoResources

&select — тут мы выбираем modResource (ресурсы, т.е. страницы сайта), и кол-во ресурсов count из временной таблицы Children, которую мы создаем в &leftJoin (таблицы Children в базе данных не существует). В шаблоне tpl мы сможем использовать плейсхолдер [[+count]].

&leftJoin — создаем временную таблицу, куда помещаем те записи, у которых parent соответсвует id базовому modResource, и методом leftJoin связываем ее с "базовой" modResource. Также после AND мы указываем условие для выборки уже этих самых потомков.

&where — Так как мы связали через leftJoin базовую modResource (которую и хотим выбрать) и временную таблицу Children, то мы можем выюрать только те записи, в которых Children.id не равны не пустые, т.е. базовый modResource, у которых есть прямые потомки.

Минум метода — он считает только прямых потомков. Чтобы посчитать всех пложенных потомков используйте сниппет countChildren (на этой странице ниже).

Код вызова сниппета pdoResources

[[!pdoResources?
    &parents=`0`
    &depth=`0`
    &tpl=`@INLINE <li>[[+pagetitle]] — [[+count]]</li>`
    &limit=`0`
    &select=`{
      "modResource":"id, pagetitle",
      "Children":"COUNT(Children.id) as count"
    }`
    &leftJoin=`{
      "Children":{"class":"modResource", "on":"modResource.id = Children.parent AND (Children.deleted != 1 AND Children.published = 1)"}
    }`
    &where=`{"Children.id:IS NOT":null}`
    &sortby=`{"id":"ASC"}`
    &groupby=`modResource.id`
  ]]

Также, теоретически мы можем основываться на параметре isfolder у ресурса. То есть когда в ресурс становится парентом для другого ресурса эта настройка автоматически переводится в положение true. Однако проблема в том, что если мы уберем потомка, бывший «родитель» так и останется с isfolder = true. В принципе можно написать плагин, или еще как-то привязаться этой настроке. Но это все равно менее надежно, чем выборка по фактическому положению дел в БД. Просто имейте в виду, что такой вариант тоже есть.

Отобразить кол-во потомков в pdoMenu для категорий товаров minishop2

[[pdoMenu?
  &parents=`[[*id]]`
  &level=`0`
  &tplOuter=`@INLINE [[+wrapper]]`
  &tplStart=`@INLINE `
  &tpl=`catalog_categories_tpl`
  &tplParentRow=`catalog_categories_tpl`
  &where=`{"class_key:=":"msCategory"}`
]]

Чанк catalog_categories_tpl

<li>
  <a href="[[+link]]" [[+attributes]]>
    [[+menutitle:default=`[[+pagetitle]]`]]
    <span>[[!countChildren? &parent=`[[+id]]`]]</span>
  </a>
</li>

Код сниппета countChildren

$count = 0;
$parent = isset($parent) ? (integer) $parent : 0;

// Define Parents
$q = $modx->newQuery('modResource');
$q->where(array(
  'class_key' => 'msCategory' // Только категории Minishop
  ));
$q->select(array(
  'id',
  'parent'
));
$q->prepare();
$q->stmt->execute();
$res = $q->stmt->fetchAll(PDO::FETCH_ASSOC);

$parent_ids = array($parent);
$i = 0;
while(true){
  $i++;
  $action = false;
  foreach($res as $v){
    if(in_array($v['parent'], $parent_ids) AND !in_array($v['id'], $parent_ids)){
      $parent_ids[] = $v['id'];
      $action = true;
    }
  }
  if(!$action || $i > count($res)){
    break;
  }
}
//return $i;

if ($parent > 0) {
  $q = $modx->newQuery('modResource');
  $q->where(array(
    'parent:IN' => $parent_ids
    ));
  $q->select(array(
    'id'
  ));
  $q->prepare();
  $q->stmt->execute();
  $count = count($q->stmt->fetchAll(PDO::FETCH_ASSOC));
  
}
return (string) $count;

Комментарии (0)

  1. Напишите первый комментарий
*Комментарий будет опубликован после проверки модератором

Похожие статьи

Генератор настроек MIGX

Документация на русском по MODX MIGX

pdoPage и getImageList - Постраничная навигация MIGX

Подсказки по работе и заготовки для MiniShop2

Импорт и экспорт в MiniShop2. Реализация 1

Как включить HTTPS (SSL) в MODX - Подробная инструкция

Генерация YML для выгрузки в маркет

Примеры работы с API MODX

Примеры выборки where, optionFilters, innerJoin

pThumb - ресайз изображений. Примеры использования.

Расширение свойств товаров minishop2

Примеры использования

Сайт на обслуживании (выключить сайт)

Добавить в письмо контактную информацию

Вывести getImageList только если он не пустой

Тип поля "Список ресурсов" (resourcelist) с ограничением по родителю (parents)

Оформление и настройка easyComm. Комментарии и отзывы на сайте.

Поиск на сайте с пакетом SimpleSearch

Подсчет и вывод количества потомков ресурса в MODX

Простая и симпатичная галерея fancybox

Галерея. Вывести обложки альбомов и фотографии

Вывод tv-параметров в формате -

Отредактировать письмо о заказе - добавить ТВ поле, или что-то еще

Quip для MODX. Более рабочий вариант

Сниппет для вывода размера и расширения файла

pdoResources Заготовки для работы

Простой аудио-плеер HTML5

Вывести список всех опций MiniShop2

Слайдер Slick slider в контенте ресурса

Как контролировать кэш CSS и скриптов

Изменить цену на товар в зависимости от количества при добавлении в корзину minishop2

Подключить MODX в стороннем PHP файле

Простейшая авторизация

Как создать ресурс процессором $modx->runProcessor('resource/create', $props)

Красивое адаптивное меню под pdoMenu

Массово обновить ТВ, или другое поле через базу

Сообщение о том, что сайт использует Cookie

Создать свою страницу в админке

Изменить формат номера заказа

Получить grandparent. Вывести родитель родителя

Симпатичный список файлов, загружаемых к ресурсу через MIGX

Установить шаблон по-умолчанию для новых, создаваемых ресурсов

Вывести все доступные плейсхолдеры

Отредактировать шаблон письма

Создать источник файлов

Добавить скрипт перед тегом body

Общая сумма по каждому товару в корзине Minishop2

Создать раздел с паролем на сайте MODX

Что делать если ее приходит почта администратору

Фильтрация по TV параметрам в msProducts

Дата на русском

FontAwesome - часто используемые иконки для шаблонов MODX

Создать пакет с пользовательской таблицей

Заготовки для работы

Загрузка сниппета после загрузки страницы через AjaxSnippet

Курсы валют с cbr.ru на PHP

getResources заготовки

Обязательный чекбокс при оформлении заказа

Обработка остатков заказа в miniShop2

Соответствие названия классов с названиями таблиц в MySQL

Разбить вывод pdoResources на несколько колонок (блоков)

Баннеры с использованием BannerY

Обновить alias (псевдоним) у всех ресурсов

CSS для постраничной навигации pdoPage

Вывести время загрузки (формирования) страницы

Расширить таблицу site_content (объект modResource) за 5 минут

Вырезать кавычки — фильтр-сниппет MODX

Счетчик посещений и скачиваний для сортировки ресурсов

Бесплатная доставка от 5000 рублей в MiniShop2

Динамическое поле emailSubject в FormIt

Скрыть информацию о том, что сайт работает на MODX

Отсортировать ресурсы по количеству комментариев Quip MODx

Изменить цену на товар, если в корзине лежит товар из особой категории minishop2

Создать редирект через autoRedirector API

Cортировать по списку id в pdoResources и pdoTools

Ответ для сервиса moneta.ru

Вывести 404 ошибку по настройке TV MODX

Email сделать не обязательным полем

Как разместить исходный код сниппета на сайте, в документации

Ускорить установку MODX revo до пары кликов

Постраничная навигация — набор параметров и CSS PdoPage

Сделать все элементы статичными для Git и IDE

Не работает подгрузка товаров ajax mfilter2 на мобильном

Сделать поле размер обязательным

Настройка стилей для комментариев Tickets

Подключить текстовой редактор к доп. полям ресурса

Динамическая замена шаблона ресурса - плагин

Кастомный чанк для AdminPanel

Разместить корзину внутри блока с оформлением заказа

Плагин для формирования замороженных URL с редиректом

xPDO Выборка из одной таблицы с зацепкой значения из другой

Приветственный экран / заглушка на сайт

Вложенные условия в xPDO MODX

Вывести список всех родителей в ТВ поле ресурса

Как получить данные пользователя сразу после авторизации через API

Вывести список всех емэйлов miniShop2

Если getParentIds не работает в плагине

Контролировать кэширование файлов CSS и JS MiniShop2

Не приходят / не отправляются письма - в чем причина?

Кэширование в MODX: использование $modx->cacheManager

Наш сайт использует куки, нажмите «ОК» если вы не против
OK