Вывод tv-параметров MODx в формате [название TV] - [значение TV]

Задача - вывести списосок всех или почти всех TV-параметров данного ресурса в связке Название tv-парметраЗначение tv-параметра чтобы получить симпатичную табличку в частности с характеристиками товара в магазине. Возможно кто-то может вопросить "А зачем такое городить, когда можно просто использовать MIGX-таблицы?". Все верно, отличный, экономичный способ, но это магазин, и товары фильтруются с помощью mFilter2, а дзен кастомных методов фильтрации на данный момент не освоен. В любом случае сниппет имеет право на жизнь.

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

if(empty($tpl) || !$modx->getChunk($tpl)){
    return echo "Не указан или не существует чанк";
}
$q = $modx->newQuery('modTemplateVarResource');
$q->select(array(
   'modTemplateVarResource.value as value',
   'tv.caption as name'
));
$q->innerJoin('modTemplateVar', 'tv', 'tv.id = modTemplateVarResource.tmplvarid');
$q->where(array(
    "modTemplateVarResource.contentid" => $modx->resource->get('id'),
    "tv.category" => "0" // Выведуться только TV, которые без категории (можно удалить или заменить категорию)
    ));
$q->limit(50);
$q->prepare();
$q->stmt->execute();
$result = $q->stmt->fetchAll(PDO::FETCH_ASSOC);
$output = "";
foreach($result as $v){
    $output .= $modx->getChunk($tpl,$v);
}
echo $output;

Доступные плейсхолдеры - [[+name]],[[+value]].

  • Пример чанка print_props_tpl: <li>[[+name]]: [[+value]]</li>
  • Пример вызова: [[!print_props?tpl=`print_props_tpl`]]

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

  1. Evgeny 06 марта 2019, 21:58 # 0
    Подскажите пожалуйста что нужно добавить чтобы выводились только те параметры значения которых заполнены (имеют более 1 символа)
    *Комментарий будет опубликован после проверки модератором

    Комментарии easyComm

    Наталья 20 мая 2018, 12:07

    А как сделать, чтобы "tv.category" тоже задавалась при вызове сниппета?

    Администратор

    Извините, не понял вопрос..

    [MODx] Генератор настроек MIGX

    [MODx, MIGx] Документация на русском по MIGX

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

    [MODx] minishop2 tips

    [JS] Маска для ввода телефона +7(___)___-__-__

    [MODx, miniShop2] Генерация YML для выгрузки в маркет

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

    [MODx] Подсказки по API

    [OpenCart] Вывести на главную все категории с картинками

    [MODx, MIGX] Примеры использования

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

    Универсальная форма обратной связи — feedBackForm

    [PHP, JSON] Пример перевода с помощью Yandex Translate API

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

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

    [Opencart] Вернуть английский язык, если вы его удалили

    [OpenCart] Вывести модуль напрямую через контроллер

    [MODx, Quip] Более рабочий вариант.

    [MODX, MIGX] Вывести getImageList только если он не пустой

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

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

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

    [MODx] Вывод tv-параметров в формате [название TV] - [значение TV]

    [PHP] Простое логирование

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

    Все записи