Новости 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 Гость просматривают эту тему.
  • 2 Ответов
  • 2196 Просмотров
*

Ahmad

  • Осваиваюсь на форуме
  • 15
  • 0 / 0
Ошибка sql в админке
« : 21.10.2008, 10:41:06 »
Зашел пару дней назад в админку сайта и при попытке добраться до содержимого:

DB function failed with error number 1195
Table 'c' is marked as crashed and last (automatic?) repair failed SQL=SELECT c.*, g.name AS groupname, cc.name, u.name AS editor, f.content_id AS frontpage, s.title AS section_name, v.name AS author FROM jos_content AS c LEFT JOIN jos_categories AS cc ON cc.id = c.catid LEFT JOIN jos_sections AS s ON s.id = c.sectionid LEFT JOIN jos_groups AS g ON g.id = c.access LEFT JOIN jos_users AS u ON u.id = c.checked_out LEFT JOIN jos_users AS v ON v.id = c.created_by LEFT JOIN jos_content_frontpage AS f ON f.content_id = c.id WHERE c.state >= 0 AND c.catid = cc.id AND cc.section = s.id AND s.scope = 'content' ORDER BY cc.ordering, cc.title, c.ordering ASC LIMIT 50

На сайте "Нет объектов для отображения!"

Весь контент отсутствует.
Joostina 1.1.1

*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
Re: Ошибка sql в админке
« Ответ #1 : 21.10.2008, 11:05:05 »
Выполните в phpMyAdmin следующий запрос:

Код: sql
REPAIR TABLE jos_content;

Если после этого ошибка не устранится, то значит эта таблица БД повреждена без возможности восстановления. В этом случае вам может помочь только восстановление базы из резервной копии (если таковая имеется).
*

Ahmad

  • Осваиваюсь на форуме
  • 15
  • 0 / 0
Re: Ошибка sql в админке
« Ответ #2 : 21.10.2008, 11:18:08 »
 Ответ MySQL: Документация
#1195 - Table 'jos_content' is marked as crashed and last (automatic?) repair failed

Похоже придется откатывать...
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Не работает пункт меню в админке Новый материал

Автор NICTO

Ответов: 8
Просмотров: 4843
Последний ответ 01.05.2022, 19:01:23
от Maksdal
В админке пропали заголовки материалов

Автор djos

Ответов: 0
Просмотров: 2393
Последний ответ 26.09.2013, 05:42:47
от djos
Где ошибка. $database- ?

Автор Alexasha

Ответов: 0
Просмотров: 1989
Последний ответ 11.07.2013, 21:17:19
от Alexasha
Ошибка при переносе на новый хост

Автор mo0f

Ответов: 3
Просмотров: 3059
Последний ответ 15.04.2013, 09:59:46
от Werber
Ошибка при установке модулей/компонентов:JFTP::store: Bad response. Warning! Failed to move file

Автор innovation

Ответов: 3
Просмотров: 16392
Последний ответ 13.03.2011, 20:11:15
от Alvi