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

inf82

  • Новичок
  • 3
  • 0 / 0
фоновые изображения
« : 07.04.2010, 15:38:05 »
Делаю шаблон который должен выглядеть вот так

"Top" и "End" это картинки. Надо чтобы нижняя картинка была всегда внизу сайта, в зависимости от количества наполнения. И чтобы текст (т.е. content) был поверх этих двух картинок.
вот куски кода.
index.php
[spoiler title=index.php]
Код: php
<body>
<div id="wrap">
<div id="sidebar">
<jdoc:include type="modules" name="left" style="xhtml" />
</div>
<div id="content">
<jdoc:include type="module" name="breadcrumbs" style="none" />
<jdoc:include type="component" />
</div>
<div id="sidebar-2">
<jdoc:include type="modules" name="right" style="xhtml" />
</div>
</div>  
<div id="topdiv">&nbsp;</div>
<div id="enddiv">&nbsp;</div>
</body>
[/spoiler]

template.css
[spoiler title=template.css]
Код: css
#topdiv {
background-image:url(../images/top.png);
background-repeat: no-repeat;
width:100%;
height:360px;
background-position: center;
top:0px;
position:absolute;
}

#enddiv {
background-image:url(../images/end.png);
background-repeat: no-repeat;
width:100%;
height:440px;
background-position: center;
bottom:0px;
position:absolute;
}

body {
text-align:center;
background-color: #FFF;
}

#wrap {
width:auto !important;
text-align:left;
}

#content {
float:left;
width:50%;
}

#sidebar,#sidebar-2 {
float:left;
width:25%;
}
[/spoiler]

Что надо исправить ?
« Последнее редактирование: 07.04.2010, 18:07:35 от inf82 »
*

slyboots

  • Новичок
  • 2
  • 0 / 0
Re: фоновые изображения
« Ответ #1 : 07.04.2010, 18:57:39 »
Почитай про наложение слоев, например это http://www.htmlbook.ru/content/?id=99
*

Alldar

  • Завсегдатай
  • 1504
  • 195 / 1
Re: фоновые изображения
« Ответ #2 : 07.04.2010, 19:04:44 »
Для END сделай фон для <body> и прибей его к низу
А для Top создай отдельный блок с фоном
*

inf82

  • Новичок
  • 3
  • 0 / 0
Re: фоновые изображения
« Ответ #3 : 08.04.2010, 07:05:52 »
Почитай про наложение слоев, например это http://www.htmlbook.ru/content/?id=99
вот кстати про z-index тоже вопрос был.
Можно ли в моем шаблоне назначить z-index:3 блоку "wrap" а "Top" и "End" z-index:1 и z-index:2.
А то я пробовал но как понял на "content" (т.е. <jdoc:include type="component" /> ) z-index никак не влияет.

Для END сделай фон для <body> и прибей его к низу
А для Top создай отдельный блок с фоном
Попробую, но хотелось бы чтобы <body> не был задействован в этом.
*

Rezet

  • Захожу иногда
  • 57
  • 1 / 0
Re: фоновые изображения
« Ответ #4 : 15.04.2010, 12:52:31 »
Попробую, но хотелось бы чтобы <body> не был задействован в этом.
Не вижу в этом ничего плохого
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться