Вывод 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" тоже задавалась при вызове сниппета?

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    Вывод 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

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

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

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

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

    getResources заготовки

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    Вывести 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