Новости Joomla

Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод...

Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод...

👩‍💻 Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод triggerEvent(), с помощью которого раньше вызывались события для плагинов. Теперь чтобы в своём коде вызвать событие для плагина и получить от него результаты нужно:- создать объект класса события- передать в него параметры

use Joomla\CMS\Event\AbstractEvent;use Joomla\CMS\Factory;use Joomla\CMS\Plugin\PluginHelper;// Грузим плагины нужных группPluginHelper::importPlugin('system');// Создаём объект события$event = AbstractEvent::create('onAfterInitUniverse', [    'subject' => $this,    'data'    => $data, // какие-то данные    'article' => $article, // ещё материал вдовесок    'product' => $product, // и товаров подвезли]);// Триггерим событиеFactory::getApplication()->getDispatcher()->dispatch(    $event->getName(), // Тут можно строку передать 'onAfterInitUniverse'    $event);// Получаем результаты// В случае с AbstractEvent это может быть не 'result',// а что-то ещё - куда сами отдадите данные.// 2-й аргумент - значение по умолчанию, // если не получены результаты$results = $event->getArgument('result', []);
Плюсы такого подхода - вам не нужно запоминать порядок аргументов и проверять их наличие. Если вы написали свой класс события, то в плагине можно получать аргументы с помощью методов $event->getArticle(), $event->getData(), $event->getProduct() и подобными - реализуете сами под свои нужды. Если такой класс события написали, то создаёте экземпляр своего класса события и укажите его явно в аргументе eventClass
use Joomla\Component\MyComponent\Administrator\Event\MyCoolEvent;$event = MyCoolEvent::create('onAfterInitUniverse', [    'subject'    => $this,    'eventClass' => MyCoolEvent::class, // ваш класс события    'data'       => $data, // какие-то данные    'article'    => $article, // ещё материал вдовесок    'product'    => $product, // и товаров подвезли]);
Ожидаемо, что класс вашего события будет расширять AbsractEvent или другие классы событий Joomla.🙁 Есть неприятный нюанс - нельзя просто так вызывать событие и ничего не передать в аргументы. Аргумент subject обязательный. Но если вы всё-таки не хотите туда ничего передавать - передайте туда пустой stdClass или объект Joomla\registry\Registry.
@joomlafeed#joomla #php #webdev

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

Infosakh

  • Завсегдатай
  • 1257
  • 67 / 0
SQL запрос
« : 25.09.2010, 12:31:23 »
Добрый вечер!  ^-^ Увидел на форуме тему про табы (закладки) в flypage VM и решил сделать тоже самое у себя. Всё получилось, всё отлично. Решил пойти еще дальше. Суть проблемы. Тематика сайта у меня игры. Сделал 3 автоматические закладки: Описание, Скриншоты, Мнение покупателей. Использовал  Magic Tabs и Scriptgrator Проблема в том что я хочу добавить четвертую закладку: Системные требования. Знаю как её добавить, но ручками править более 2 тысяч позицией довольно таки нуторно. Вот собственно вопрос, какой сделать запрос в SQL чтобы указать следующее условие. Если есть в описании товара (PRODUCT_DESC) слово Системные то добавить перед ним такой вот код: |||| Системные требования:: Вот в принципе и все что мне нужно, тогда эта вкладка во всех товарах появится  ^-^
*

danik.html

  • Живу я здесь
  • 2650
  • 353 / 4
Re: SQL запрос
« Ответ #1 : 25.09.2010, 15:07:14 »
Код: sql
UPDATE jos_vm_product
SET `product_desc`= REPLACE(`product_desc`, 'Системные', '|||| Системные')
【Мегапак Virtuemart:
 • метатеги (description,keywords)
 • заголовки (title)
 • красивые алиасы (чпу) без тормозов и дублей!
*

Infosakh

  • Завсегдатай
  • 1257
  • 67 / 0
Re: SQL запрос
« Ответ #2 : 25.09.2010, 15:42:00 »
Код: sql
UPDATE jos_vm_product
SET `product_desc`= REPLACE(`product_desc`, 'Системные', '|||| Системные')
а эта функция случайно не заменит слово Системные на |||| Системные:: ? мне нужно именно чтобы перед найденным словом системные поставилось выражение |||| Системные::
« Последнее редактирование: 25.09.2010, 15:45:25 от Infosakh »
*

danik.html

  • Живу я здесь
  • 2650
  • 353 / 4
Re: SQL запрос
« Ответ #3 : 25.09.2010, 15:46:20 »
Включи фантазию ))
UPDATE jos_vm_product
SET `product_desc`= REPLACE(`product_desc`, 'Системные', ' |||| Системные:: Системные')
【Мегапак Virtuemart:
 • метатеги (description,keywords)
 • заголовки (title)
 • красивые алиасы (чпу) без тормозов и дублей!
*

Infosakh

  • Завсегдатай
  • 1257
  • 67 / 0
Re: SQL запрос
« Ответ #4 : 25.09.2010, 15:48:26 »
точно  ;D сейчас попробую  ^-^
*

Infosakh

  • Завсегдатай
  • 1257
  • 67 / 0
Re: SQL запрос
« Ответ #5 : 25.09.2010, 16:14:20 »
все получилось +1  :D
*

asimo

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
Re: SQL запрос
« Ответ #6 : 29.05.2012, 21:06:09 »
Цитировать
А не подскажите как написать sql запрос в VirtueMart что бы во все описание товаров после например слова "прочие" добавить некоторый HTML код?
Разобрался!
« Последнее редактирование: 01.06.2012, 06:39:39 от asimo »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Изменить запрос поиска mod_virtuemart_search

Автор Tokyo

Ответов: 1
Просмотров: 1398
Последний ответ 06.06.2013, 02:03:57
от fsv
Требуется сформировать запрос на выборку из базы

Автор evsmusic

Ответов: 1
Просмотров: 1318
Последний ответ 26.03.2012, 19:15:39
от evsmusic