Новости Joomla

Рендер пользовательского поля внутри другого пользовательского поля. Joomla 5.3

Писал ранее о том, как внутри одного пользовательского поля рендерить другое пользовательское поле. Применил для этого возможность Joomla обращаться к методам плагинов напрямую. Процитирую строчку кода из предыдущего поста:

<?php
$joomlaFieldContentPlugn->onContentPrepare('com_content.article', $fakeItem, $app->getParams());

Joomla постепенно переходит от простого указания аргументов для триггеров плагинов к собственным классам событий. Это позволяет не запоминать порядок передачи аргументов класса и использовать человекопонятные методы $event->getContext(), $event->getItem() и т.д. А то в одном месте в Joomla было $article, в другом - $item, в третьем ещё как-то... Порядку больше становится.

Сегодня обновил сайт клиентов до Joomla 5.3. В ней обновили контент-плагин fields и мой финт ушами с вызовом метода плагина отвалился потому, что я передавал в нём 3 аргумента, вместо одного. И для события onContentPrepare это должен быть объект класса ContentPrepareEvent. Как меняется фрагмент кода из предыдущего поста:

<?php
// мы находимся в файле макета поля

use Joomla\CMS\Event\Content\ContentPrepareEvent;
use Joomla\CMS\Factory;

$app = Factory::getApplication();
$fakeItem = new \stdClass();
// Получаем id текущего материала из объекта Input
$fakeItem->id = $app->getInput()->getInt('id');
// {field 29} - это шорт код вставки поля с id 29 - "ассортимент проекта"
// к содержимому поля конкатенируем шорт-код для обработки
$fakeItem->text = $field->value . '{field 29}';
// Получаем объект плагина
$joomlaFieldContentPlugn = $app->bootPLugin('fields', 'content');
// вызываем метод обработки напрямую
// вместо 3-х аргументов теперь указываем один
// это объект класса ContentPrepareEvent
$joomlaFieldContentPlugn->onContentPrepare(new ContentPrepareEvent('onContentPrepare', [
            'context' => 'com_content.article',
            'subject' => $fakeItem,
            'params'  => $app->getParams(),
            'page'    => 0,
        ]));
// выводим оба поля
echo $fakeItem->text;

@webtolkru 

Вышел релиз Joomla 5.3.0

Вышел релиз Joomla 5.3.0

Проект Joomla с радостью объявляет о выходе Joomla 5.3 — последней минорной версии в серии Joomla 5.

Этот релиз сосредоточен на продуманных улучшениях, которые совершенствуют работу с CMS. От лучшей организации файлов и журналирования задач до расширенной обработки электронной почты и улучшенной доступности — Joomla 5.3 помогает администраторам и разработчикам работать более эффективно, сохраняя ваш сайт современным, безопасным и готовым к будущему.

0 Пользователей и 1 Гость просматривают эту тему.
  • 3 Ответов
  • 1742 Просмотров

Добавление данных в БД
« : 18.08.2008, 14:30:58 »
ХЕЛП! Не пойму в чем дело, надо чтобы из скрипта данные заносились в БД, таблица существует. Как только не пробовал.
Почему может не работать такой запрос в скрипте?

$database->setQuery( "insert into subscribers(id, code, number, email, tel, model) VALUES (NULL,'$code','$number','$email','$tel','$model')" );
*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
Re: Добавление данных в БД
« Ответ #1 : 18.08.2008, 14:38:08 »
Думаю проблема в том, что запрос вы установили, а выполнить его не выполнили. Добавьте после этого кода еще одну строчку:

Код: php
$database->query();

Re: Добавление данных в БД
« Ответ #2 : 18.08.2008, 17:50:14 »
это граничит с шаманством, так как я считал, что конструкция которую я написал это и есть запрос. Но добавив вашу строку, данные начали заноситься в БД :D
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Добавление данных в БД
« Ответ #3 : 18.08.2008, 18:04:30 »
$database->setQuery() - собственно тело запроса
$database->query() - выполнение запроса
мне кажется что некоторая разница все-таки есть :)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как в PhpMyAdmin увеличить максимальный размер при импорте базы данных?

Автор prossvika

Ответов: 14
Просмотров: 42040
Последний ответ 15.01.2012, 12:47:14
от root34
Невозможно подключиться к серверу базы данных

Автор ver

Ответов: 7
Просмотров: 11973
Последний ответ 06.12.2010, 19:41:43
от dedanet
Добавление новостей пользователями

Автор ParaNoid_

Ответов: 2
Просмотров: 3812
Последний ответ 22.05.2010, 09:56:46
от BULA
Синхронизация 2 сайтов с одной базой данных.

Автор Quexx

Ответов: 25
Просмотров: 11082
Последний ответ 23.01.2010, 21:52:44
от SSStylish
Можно автоматизировать добавление контента?

Автор Rojas

Ответов: 2
Просмотров: 2532
Последний ответ 29.10.2009, 01:31:01
от Rojas