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

Lekkter

  • Осваиваюсь на форуме
  • 11
  • 1 / 0
Menu JavaScript+jQuery+html/css
« : 22.03.2013, 14:59:15 »
People! I need help!   >:(
Имеется меню на описанных в топике технологиях. Каркас - многоуровневый список, ниспадающее раскрытие списка - сответственно на jsе. Как прикрутить его к шаблону?!
Зарание благодарен за помощь и прошу не бить палками неофита! :'(
*

darkghost

  • Живу я здесь
  • 2212
  • 97 / 0
Re: Menu JavaScript+jQuery+html/css
« Ответ #1 : 22.03.2013, 16:28:33 »
нужно вставить открытый код этого самого описанного в Топике меню или что?
*

Lekkter

  • Осваиваюсь на форуме
  • 11
  • 1 / 0
Re: Menu JavaScript+jQuery+html/css
« Ответ #2 : 22.03.2013, 17:01:18 »
Нужно сделать так, чтобы меню mod_mainmenu отрображалось как ниспадающий список. Я просто не очень пойму куда привинтить каркас. В файл шаблона модуля (modules/mod_mainmenu/legacy.php) или тыркать его отдельным подключаемым в <div> модулем с уже подкрученым к нему JS-кодом и библиотекой....
« Последнее редактирование: 22.03.2013, 17:07:47 от Lekkter »
*

darkghost

  • Живу я здесь
  • 2212
  • 97 / 0
Re: Menu JavaScript+jQuery+html/css
« Ответ #3 : 23.03.2013, 13:53:15 »
вообще-то, при установке какого-то специфического модуля с дополнительными библиотеками (например слайдеры или галереи), ссылки на их библиотеки устанавливаются автоматом в область <head>
если такого не происходит у Вас, то в шаблоне сайта, в область <head> пропишите ссылки на библиотеки вручную    
*

Lekkter

  • Осваиваюсь на форуме
  • 11
  • 1 / 0
Re: Menu JavaScript+jQuery+html/css
« Ответ #4 : 29.03.2013, 11:26:46 »
Вопрос решён. Спасибо за помощь.
Решение оказалось не сильно сложным. Каркас был загнана в файл templates/system/html/modules.php в виде нового стиля вывода модуля. Сисы менюхи запилены в отдельный CSS файл и подключены вместе с JS-функционалом к index.php.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Подскажите по совместимости jquery

Автор M60aut

Ответов: 0
Просмотров: 1268
Последний ответ 10.02.2017, 11:05:05
от M60aut
Для чего нужны пустые index.html в каждой папке?

Автор webusver

Ответов: 13
Просмотров: 11350
Последний ответ 12.11.2016, 18:23:42
от ProtectYourSite
Подключение jQuery к Joomla 1.5

Автор Sergei_Han

Ответов: 1
Просмотров: 1640
Последний ответ 23.04.2015, 14:23:31
от kik84
Как убрать.html у разделов и оставить у конечных страниц?

Автор Леонид

Ответов: 0
Просмотров: 1514
Последний ответ 17.04.2015, 05:03:37
от Леонид
<jdoc:include type="module" /> остается в HTML коде

Автор dema8912

Ответов: 8
Просмотров: 2624
Последний ответ 12.02.2015, 15:48:39
от stanbstan