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

TV Поле migx_documents — вкладки формы

[
  {
  "caption": "Заголовок",
  "fields": [
    {
    "field": "file",
    "caption": "Файл",
    "inputTVtype": "file",
    "sourceFrom": "migx"
    },
    {
    "field": "class",
    "caption": "Тип документа",
    "inputTVtype": "listbox",
    "inputOptionValues": "Word==doc_word||PDF==doc_pdf"
    },
    {
    "field": "name",
    "caption": "Название",
    "inputTVtype": "text"
    }
  ]
  }
]

TV Поле migx_documents — разметка колонок

[{
  "sourceFrom": "migx",
  "header": "Файл",
  "dataIndex": "file"
},
    {
  "header": "Название",
  "dataIndex": "name"
    },{
  "header": "Тип документа",
  "dataIndex": "class"
}]

Чанк migx_documents_tpl

<li class="[[+class]]">
  <a href="[[+file]]" target="_blank">[[+name]]</a>
  <span class="filesize">[[+file:FileSize]]</span>
</li>

Вызов на странице:

<ul class="document_page_list">
[[!getImageList?
	&tvname=`migx_documents`
	&tpl=`migx_documents_tpl`
	&docid=`[[*id]]`
	&limit=`999`
]]
</ul>

Сниппет FileSize

В заметке [MODX] Узнать размер файла

CSS

Кстати, симпатичные иконки я нагло взял в интерфейсе почты mail.ru..

.document_page_list{
  margin: 0 auto;
}
.document_page_list li {
  list-style-type: none;
  padding: 10px 0 10px 85px;
  font-size: 16px;
  margin-bottom: 7px;
}
.document_page_list li a{
  text-decoration: none;
  border-bottom: 1px solid;
}

.document_page_list li span{
  font-size: 12px;
  color: #999;
  margin-left: 5px;
}

.document_page_list li.doc_pdf{
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxNjAgMTYwIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxNjAgMTYwIj48cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIgZmlsbD0iI0Y5NjY1NyIgZD0iTTEyMy44MzMgMEgxMEM0LjQ3NyAwIDAgNC41IDAgMTB2MTQwYzAgNS41IDQuNSAxMCAxMCAxMGgxNDBjNS41MjMgMCAxMC00LjQ3NyAxMC0xMFYzNi4xNjdDMTQ5LjMzMyAyNS41IDEyOSA1LjIgMTIzLjggMHoiLz48cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIgZmlsbD0iIzk5MjExMiIgZD0iTTEyNCAwbDM2IDM2aC0yNmMtNS41MjMgMC0xMC00LjQ3Ny0xMC0xMFYweiIvPjxwYXRoIGZpbGw9IiM5OTIxMTIiIGQ9Ik01OC44NTggNjYuOTljLS41MjItMS41OTUtMS44MDYtMy4wMTUtMi45NDYtNC4yNi0xLjE0LTEuMjQ1LTIuNjE4LTEuNzktNC40MzQtMi41NS0xLjgxNy0uNzU4LTYuNjEtMS4xMzctNi42MS0xLjEzN2wtMTQuOTE1LjEyNHY0MS43ODhoOC4xMDV2LTExLjg5aDYuODFjMi41OSAwIDQuNzkyLS4zOCA2LjYxLTEuMTM4IDEuODE1LS43NTggMy4yOTMtMS43NiA0LjQzMy0zLjAwNSAxLjE0LTEuMjQ0IDMuMzMtMi45NzggMy44NTQtNC41OTMuNTIyLTEuNjE2LjMzLTYuMjU0LjMzLTcuOTI4IDAtMS43MDMtLjY5My0zLjgwMy0xLjE5My01LjQxM3pNNDkuNzEgNzcuOThjLS40NDUuODE2LTEuMDM0IDEuNDQ4LTEuNzY4IDEuOS0uNzM1LjQ0Ny0xLjU4NS43NS0yLjU1LjkwNC0uOTY3LjE1Ni0xLjk3Mi4yMzMtMy4wMTUuMjMzSDM4LjA2VjY3LjEyNWg0LjMxOGMxLjA0MyAwIDMgLjIgMyAuMnMxLjgxNi41IDIuNi45MDVjLjczMy40IDEuMyAxLjEgMS44IDEuODk2LjQ0NC44LjcgMiAuNyAzLjMtLjEgMS4zNzQtLjI3OCAzLjc3NC0uNzc4IDQuNTUzem00Ny42NTctNy4zODRjLS45NDctMi41NjctMi43MTMtNC43MDYtNC4zOTQtNi40MTgtMS42ODItMS43MS0zLjY3Mi0yLjk5NS01Ljk3Mi0zLjg1LTIuMjk3LS44NTYtNC43OC0xLjI4NC03LjQ0Ny0xLjI4NGgtMTMuNTZ2NDEuOTEyaDEzLjU2YzMuMTY4IDAgNS45Mi0uNTM0IDguMjYtMS42MDUgMi4zMzgtMS4wNjcgNC44OTQtMi42NiA2LjQ2LTQuNTMgMS41NjQtMS44NjUgMi44ODMtNC4wODIgMy42NTctNi42NS43NzMtMi41NjcuNzA3LTcuNDk1LjcwNy0xMC41MyAwLTMuNDQtLjMzNy00LjQ0LTEuMjM3LTcuMDQzek04OC4zNjQgODYuNGMtLjU4IDEuNTk1LTEuMzUzIDIuODg4LTIuMzIgMy44OHMtMi4wNjcgMS43MDItMy4zMDMgMi4xM2MtMS4yMzUuNDI4LTIuNTEuNjQyLTMuODI0LjY0MmgtNC44NDJWNjcuMjI1aDMuMjJjMi4yNCAwIDQuMS4zIDUuNy45NjIgMS41MjUuNiAyLjggMS42IDMuNyAyLjc3Mi45MjYgMS4yIDEuNiAyLjcgMiA0LjMuNDA1IDEuNy42IDMgLjYgNS4wNzctLjA2IDIuMzYyLS4zOTMgNC40NjItLjg5MyA2LjAzNHptNDEuNjgyLTI3LjM1NmgtMjYuMDc0djQxLjkxMmg4LjA4Vjg1LjA4aDkuOTY1di04LjA4MmgtOS45NjVsLS4wNTYtOS44OThoMThsLjA1LTguMDU2eiIvPjwvc3ZnPg==");
  background-repeat: no-repeat;
}
.document_page_list li.doc_word{
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxNjAgMTYwIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxNjAgMTYwIj48cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIgZmlsbD0iIzc0QjVFMyIgZD0iTTEyMy44MzMgMEgxMEM0LjQ3NyAwIDAgNC41IDAgMTB2MTQwYzAgNS41IDQuNSAxMCAxMCAxMGgxNDBjNS41MjMgMCAxMC00LjQ3NyAxMC0xMFYzNi4xNjdDMTQ5LjMzMyAyNS41IDEyOSA1LjIgMTIzLjggMHoiLz48cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIgZmlsbD0iIzM5NTVCOCIgZD0iTTEyNCAwbDM2IDM2aC0yNmMtNS41MjMgMC0xMC00LjQ3Ny0xMC0xMFYwek00NyA1MC4wMDJoMTEuODIybDYuNjczIDM5LjI1Mkw3NC4zNiA1MGgxMS40MjRsNy4xMzggMzguNyA2LjkwOC0yOC43MDRoLTYuODFWNTBIMTEzbC0xNC4zNzggNjAuMDNoLTExLjRMNzkuNTEgNzUuMDc2bC04LjAzIDM0Ljk0Nkg1OS4zNTdMNDcgNTAuMDAyeiIvPjwvc3ZnPg==");
  background-repeat: no-repeat;
}

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

  1. Иван 29 января 2023, 12:25 # 0
    100 лет на сайте у клиента не было возможности управлять загрузкой файлов. И тут их петух клюнул — срочно понадобилось. И почти по щелчку с вашим примером сделал. Не сразу понял, что все создается в обычном дополнительном поле. Лез в управление MIGX

    Все отлично работает, спасибо!
    *Комментарий будет опубликован после проверки модератором

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

    Генератор настроек 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