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

skylink67

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
Ни как не получается у меня сделать выпадающее меню для моего сайта: http://starsky67.ru, при нажатии на портфолио подпункты меню почему то сдвигаются направо, Помогите решить проблему
*

skylink67

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
Я хочу чтобы при наведении курсора мыши на пункт портфолио высвечивались под пункты меню
*

vegasstudio

  • Захожу иногда
  • 51
  • 1 / 0
Добрый день

попробуйте в файле стиля layout.css шаблона beez3 для блока
Код
#header ul.menu li
{}
дописать свойство
Код
  position: relative;
*

skylink67

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
Дописал, встало там где надо, но только что размер не тот и теперь подпункт меню горит всегда, а как сделать чтобы размер был нормальный и чтобы только при наведении показывался подпункт меню?
« Последнее редактирование: 23.06.2015, 18:13:40 от skylink67 »
*

skylink67

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
« Последнее редактирование: 23.06.2015, 18:44:04 от skylink67 »
*

A.Pronin

  • Новичок
  • 4
  • 0 / 0
Столкнулся с похожей проблемой, вроде все прописываю верно в менеджере меню, ставлю родительские разделы как в уроках, но подпункты меню выводятся отдельным пунктом да еще и все отображение меню ломают.
при том попытки изменить display или прописать hover вообще начинают отображать меню вертикально а не горизонтально

Вот то что лежит в layout.css
Код: css
#header ul.menu {
padding: 0 20px 0 20 px;
width: inherit;
text-align: left;
display: block;
-webkit-border-radius: 4px 4px 4px 4px;
-moz-border-radius: 4px 4px 4px 4px;
border-radius: 4px 4px 4px 4px;
margin: 0 0


}

#header ul.menu li {
display: inline;
padding: 0;
margin: 0;
position: relative;
}

#header ul.menu li a:link,#header ul.menu li a:visited,#header ul.menu li:last-child a
{
font-weight: none;
text-decoration: none;
padding: 0px 10px;
margin: 0;
display: inline-block;
margin: 0 0 0;
padding: 12px 15px;
position: relative;
border-right: 1px solid #271e08;

}

#header ul.menu li:first-child a {
border-radius: 4px 0 0 0;
margin-left: -1px
}

.moduletable_menu {
border: solid 1px #271e08;
background: #f9f9f9;
-webkit-border-radius: 4px;
-moz-border-radius: 4px;
border-radius: 4px;
padding: 20px;
margin-bottom: 20px
}

ul.menu {
margin: 0 0 20px 0;
padding: 0;
}

ul.menu,ul.menu ul {
list-style-type: none;

}

ul.menu a {
display: block;
margin: 0;
text-decoration: none;
padding: 5px 0px;
border-bottom: solid 1px #271e08;
}

ul.menu li:last-child a {
border: 0;
box-shadow: none
}

ul.menu ul {
margin: 0;
padding: 0
}

ul.menu ul a {
padding-left: 20px
}

ul.menu ul ul a {
padding-left: 30px
}

ul.menu ul ul ul a {
padding-left: 40px
}

ul.menu ul ul ul ul a {
padding-left: 45px
}
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Кликабельность псевдоэлемента в пункте меню

Автор vasilii.pupkov

Ответов: 4
Просмотров: 3228
Последний ответ 29.12.2021, 23:15:38
от v42bis
Выпадающее меню

Автор DrShepard

Ответов: 10
Просмотров: 2898
Последний ответ 20.10.2021, 12:36:16
от DrShepard
Как сделать?

Автор Twins

Ответов: 3
Просмотров: 1859
Последний ответ 01.07.2021, 13:11:51
от xpank
Как сделать кнопку формы аккаунта?

Автор Evgen Kulibin

Ответов: 0
Просмотров: 1023
Последний ответ 22.04.2021, 22:15:06
от Evgen Kulibin
Как сделать плавающий модуль?

Автор THeCMeX

Ответов: 2
Просмотров: 1181
Последний ответ 08.03.2021, 22:21:01
от Flexderection