Расширить таблицу site_content за 5 минут

Обычно расширять таблицу site_content следует если сайт относительно большой, или есть какие-то операции с TV-параметрами, которые начинают потреблять больше ресурсов, чем вы того хотели бы.

Я, честно говоря, заморочнулся прежде чем нашел у одного из гуру MODX нижеследующие решение. К сожалению уже не помню кто имено был автор, но я пытался искать по-разному: "Добавить столбцы в таблицу site_content", "Собственные свои поля в таблицу site_content", "Расширить объект modResource". Надеюсь эта статья будет полезной шпаргалкой не только мне.

Последовательность действий:

  1. Создаем в phpMyAdmin дополнительные колонки. Для примера это будет st_unpublished, st_city_id.
    Внимательно пропишите все настройки. Советую смотреть в файл core/model/modx/mysql/modresource.map.inc.php. Тут найдите похожее поле, и посмотрите какие настройки прописаны тут, и что указано в таблице в phpMyAdmin
  2. Создаем TV-параметры, которые будeт зеркалом нашей новой настроки. То есть данные будут храниться и в TV, но при этом дублироваться в таблицу modx_site_content
  3. Создаем плагин и вставляем туда код, в системных событиях отмечаем OnMODXInit и OnDocFormSave.

    switch ($modx->event->name) {
      case 'OnMODXInit':
        // $modx->loadClass('msOrder');
        $modx->map['modResource']['fields']['st_city_id'] = 0;
        $modx->map['modResource']['fieldMeta']['st_city_id'] = array(
          // Какие настройки указывать тут вы поймете, найдя похожее поле в core/model/modx/mysql/modresource.map.inc.php
          'dbtype' => 'int',
          'precision' => 10,
          'attributes' => 'unsigned',
          'phptype' => 'integer',
          'null' => true,
          'default' => 0
        );
        $modx->map['modResource']['fields']['st_unpublished'] = 0;
        $modx->map['modResource']['fieldMeta']['st_unpublished'] = array(
          'dbtype' => 'tinyint',
          'precision' => '1',
          'attributes' => 'unsigned',
          'phptype' => 'boolean',
          'null' => false,
          'default' => 0
        );
        break;
      case 'OnDocFormSave':
        // Сохраняем ТВ в поле таблицы ресурса
        $resource->set('st_city_id', $resource->getTVValue('city_id'));
        $resource->set('st_unpublished', $resource->getTVValue('st_unpublished'));
        $resource->save();
          break;
    }
    

Соотвественно редактировать эти поля мы будем редактируя TV-поля. Конечно, если речь идет об использовании API, то нужно редактировать напрямую. Но учтите как работает плагин. То есть если вы через API меняете поле в modx_site_content, то следует поменять и значение TV-парамментра, иначе может быть жесть и ужас.

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

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

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

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