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

TitanFighter

  • Осваиваюсь на форуме
  • 33
  • 1 / 0
Добрый день.

Не получается закрепить скрол в нужном месте.
В прикреплении мне нужно синий блок оставить без движения, а красный чтоб скролился.

У меня получается сделать так, чтоб двигались оба, а не только красный.
Может ктото взглянуть и помочь?
apg.land/products клацните пару продуктов для сравнения и перейдите в горизонтальный просмотр

Спасибо

« Последнее редактирование: 16.03.2015, 22:46:44 от TitanFighter »
*

ShfVD

  • Давно я тут
  • 871
  • 65 / 0
*

TitanFighter

  • Осваиваюсь на форуме
  • 33
  • 1 / 0
Не желтое) Синее) Поменял уже в сообщении)

На скрине в первом посте синий блок с кнопками "Вертикально\Горизонтально" и "Удалить все из сравнения" нужно сделать неподвижными, а к остальной части, что ниже (Название колонок и само сравнение) нужно применить overflow. У меня к сожалению получается сделать overflow сразу и к кнопкам "Вертикально\Горизонтально"\"Удалить все из списка" и к остальной части, что ниже (Название колонок и само сравнение)
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
<table class="jbcompare-table horizontal"> оберните в отдельный div с указанием размеров width:100%;max-height:нужное_значение_px; и указанием соответствующих overflow
*

TitanFighter

  • Осваиваюсь на форуме
  • 33
  • 1 / 0
Спасибо большое. Все отлично)
Только вместо высоты в пикселях указал height:95%, так как от к-ва продуктов при сравнении меняется высота, а при 100% скрол размещается прямо на обрамляющей рамке.
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Высоту в % указывать - неблагодарное дело, ибо вы никогда заранее не знаете, какова высота родительского контейнера.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

CSS для позиции модуля

Автор tierex

Ответов: 3
Просмотров: 2654
Последний ответ 26.05.2023, 11:06:00
от tierex
[Решено] Как сделать чтобы фотография открылась в отдельном окне?

Автор a-two

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

Автор Mick_20

Ответов: 4
Просмотров: 2258
Последний ответ 28.05.2020, 15:45:06
от Muzzy
[Решено] UiKit: сетка на 12 колонок, а также на 7, 8, 9 и (для uikit3) 10

Автор AlekVolsk

Ответов: 1
Просмотров: 6062
Последний ответ 08.08.2019, 19:02:41
от AlekVolsk
Элемент flexbox выходит за края родителя [РЕШЕНО]

Автор dm-krv

Ответов: 3
Просмотров: 10105
Последний ответ 05.04.2019, 16:07:44
от dm-krv