Новости 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 Ответов
  • 1310 Просмотров
*

A_valancha

  • Новичок
  • 3
  • 0 / 0
Здравствуйте! Сайт работает на Joomla 2.5. В мобильной версии после нажатия на кнопку Меню все пункты и подпункты меню отображаются в развёрнутом виде. Как сделать так, чтобы отображалось только корневое меню, а меню второго и третьего уровней разворачивались по клику? Заранее благодарю за любую помощь. Новичок.

Сайт halaco.ru
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
В вашем http://halaco.ru/templates/it_planetearth/css/responsive.css для второго уровня показываете скрывать уровни, а событие клик прописываете уже в JS

Код
#icemegamenu > li > ul.icesubMenu {display: none;}

Ну или можете на ховер повесить на CSS показ подуровней (не разбирался с вашим деревом классов потому тупо весил important)
Код
.icemegamenu > ul > li:hover ul {display: block !important;}

P.S. странная логика у верстальщика меню была, будто нет медиа квери, инлайновый JS, жуть полная ))
Зачем вот эти костыли с оффсетом, непонятно.
Код
	jQuery(document).ready(function(){
var browser_width1 = jQuery(window).width();
jQuery("#icemegamenu").find(".icesubMenu").each(function(index){
var offset1 = jQuery(this).offset();
var xwidth1 = offset1.left + jQuery(this).width();
if(xwidth1 >= browser_width1){
jQuery(this).addClass("ice_righttoleft");
}
});

})
jQuery(window).resize(function() {
var browser_width = jQuery(window).width();
jQuery("#icemegamenu").find(".icesubMenu").removeClass("ice_righttoleft");
jQuery("#icemegamenu").find(".icesubMenu").each(function(index){
var offset = jQuery(this).offset();
var xwidth = offset.left + jQuery(this).width();

if(xwidth >= browser_width){
jQuery(this).addClass("ice_righttoleft");
}
});
});
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

A_valancha

  • Новичок
  • 3
  • 0 / 0
Спасибо большое, попробуем!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как убрать боковые отступы в мобильной версии шаблона?

Автор Евгений1980

Ответов: 2
Просмотров: 1612
Последний ответ 18.01.2021, 18:24:53
от arma
Ссылки в меню в мобильной версии

Автор Андрей Нестеров

Ответов: 1
Просмотров: 1984
Последний ответ 11.12.2019, 10:47:20
от sivers
не работает меню в мобильной версии.При нажатии ничего не происходит

Автор NAaTa

Ответов: 9
Просмотров: 4644
Последний ответ 10.08.2016, 23:26:59
от NAaTa
Стили галереи в мобильной версии

Автор balkan

Ответов: 0
Просмотров: 1425
Последний ответ 15.06.2016, 12:59:41
от balkan
В мобильной версии шапка сайта съезжает, полтекста исчезает

Автор lubashina

Ответов: 7
Просмотров: 3037
Последний ответ 16.04.2016, 11:53:02
от Alldar