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

JaneFaint

  • Захожу иногда
  • 121
  • 3 / 0
Всем добрый день!
Прошу помощи, как расположить блоки таким вот образом? Номер блока обозначает порядок стояния в коде. Не могу понять как прописать inline-block чтобы получилось как надо, всё какая-то каша-малаша выходит.


Спасибо.
« Последнее редактирование: 28.07.2016, 16:37:23 от JaneFaint »
*

Ilhom666

  • Завсегдатай
  • 1384
  • 184 / 0
имхо вы тут одним CSS-ом не отделаетесь, со скриптами решений много - например
*

draff

  • Гуру
  • 5801
  • 434 / 7
  • ищу работу
*

JaneFaint

  • Захожу иногда
  • 121
  • 3 / 0
То есть две колонки не подходит 65% и 34%?
Если 2 колонки, то расположение блоков в коде придется поменять., т.е будет 1,3,2,4.
Расположение в коде именно такое, чтобы при сжимании страницы они потом встали друг под другом. Если есть какой-то другой способ, буду рада узнать.
« Последнее редактирование: 28.07.2016, 11:24:06 от JaneFaint »
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Если 2 колонки, то расположение блоков в коде придется поменять., т.е будет 1,3,2,4.
Расположение в коде именно такое, чтобы при сжимании страницы они потом встали друг под другом. Если есть какой-то другой способ, буду рада узнать.
Нет такого способа, кроме как применять абсолютное позиционирование, это можно реализовать на чистом CSS, но вам придется для каждого разрешения экрана дофига всего прописывать, лучше это сделать скриптом, пример которого и дан по ссылке выше. Как альтернатива. можно воспользоваться фреймворком uikit, там подобный скрипт в базе функционала: http://getuikit.com/docs/grid-js.html
*

JaneFaint

  • Захожу иногда
  • 121
  • 3 / 0
можно воспользоваться фреймворком uikit, там подобный скрипт в базе функционала: http://getuikit.com/docs/grid-js.html
Это интересно, буду изучать.
Спасибо!
*

JaneFaint

  • Захожу иногда
  • 121
  • 3 / 0
Всё получилось! Помог uikit и его Dynamic Grid!
Всем большое спасибо!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Разобраться с цветом ссылок

Автор annetkas

Ответов: 2
Просмотров: 2671
Последний ответ 27.01.2022, 13:26:44
от annetkas
[Решено] Как сделать чтобы фотография открылась в отдельном окне?

Автор a-two

Ответов: 11
Просмотров: 2117
Последний ответ 03.11.2020, 16:57:40
от Nikolay89
[Решено] Слетает правый сайдбар на шаблоне protostar

Автор Mick_20

Ответов: 4
Просмотров: 2254
Последний ответ 28.05.2020, 15:45:06
от Muzzy
Перенос блоков

Автор Forgiving

Ответов: 0
Просмотров: 892
Последний ответ 15.03.2020, 10:22:43
от Forgiving
helix 3 не могу заставить работать position: sticky;

Автор platonische

Ответов: 0
Просмотров: 1757
Последний ответ 04.01.2020, 16:01:16
от platonische