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

Для начала нужно создать таблицу в базе данных и интегрировать ее в MODx.

  1. Установить пакет CMPGenerator.
  2. Создать таблицу с желаемой структурой через phpMyAdmin (Поле с автоинкремент долно называться id)
    Пример моей таблицы:
    CREATE TABLE IF NOT EXISTS `modx_go_feedback` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
      `name` varchar(255) NOT NULL,
      `email` varchar(255) NOT NULL,
      `message` text NOT NULL,
      `data` text NOT NULL,
      `custom1` text NOT NULL,
      `custom2` text NOT NULL,
      `custom3` text NOT NULL,
      `flag` int(11) NOT NULL,
      `phone` varchar(255) NOT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=6 ;
        
  3. В CMPGenerator нажать Create Package

  4. Создаем сниппет для тестирования:
    $output = '';// this is what the snippet will return
    // add package so xpdo can be used:
    $package_path = $modx->getOption('core_path').'components/gofeedback/model/'; //Вместо "gofeedback" написать то, что указывали в "Package Name"
    // see the scheme file and the xml model element and you will see the attribute package and that must match here
    
    $modx->addPackage('gofeedback', $package_path);  //Вместо "gofeedback" написать то, что указывали в "Package Name"
    
    // lets add some data!
    // see the scheme file and the xml object element and you will see the attribute class and that must match here
    // the class name is taken from table names without the prefixed, and is capitalized.
    $myRow = $modx->newObject('GoFeedback'); // class из файла схемы (core/components/[gofeedback]/model/[gofeedback]/[gofeedback].mysql.schema.xml)
     
    $data = array(
      'name' => 'MODX Revolution',
      'message' => 'A great CMS product...'
    );
    $myRow->fromArray($data);
     
    if ( !$myRow->save() ) {
      $output .= '<p>Could not create row</p>';
    } else {
      $output .= '<p>Created row successfully</p>';
    }
    // now lets show the data in a quick and dirty table:
    $output .= '
    <table>
        <tr>
            <th>ID</th>
            <th>Name</th>
            <th>Description</th>
        </tr>';
    $query = $modx->newQuery('GoFeedback');
    $rows = $modx->getIterator('GoFeedback', $query);
     
    /* iterate */
    $list = array();
    foreach ($rows as $row) {
        // from object to array you can also do $row->get('name');
        $row_array = $row->toArray();
     
        $output .= '
        <tr>
            <td>'.$row_array['id'].'</td>
            <td>'.$row_array['name'].'</td>
            <td>'.$row_array['message'].'</td>
        </tr>';
    }
    $output .= '
    </table>';
     
    return $output;

Далее будет создан пакет для транспортировки, и страница в админке, где можно будет простматривать данные.

Заметки и ссылки по теме:

  • https://ilyaut.ru/xpdo/
  • https://bezumkin.ru/sections/components/252/
  • https://ilyaut.ru/tips-and-tricks/create-a-build-of-modx-revo/

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

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

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

tooladmin 17 марта 2018, 22:33

https://rtfm.modx.com/xpdo/2.x/getting-started/creating-a-model-with-xpdo/defining-a-schema/

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

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

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

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

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