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

TommyDBrown

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Приветствую ребята, вновь обращаюсь за помощью, делаю магазин на JoomShopping и к фотографиям хочу подключить fancybox, но поскольку вызов данного скрипта уже идет посредством Elevatezoom решил, что нужно как то их скрестить
Вообщем вот первый кусочек кода:
Код
//initiate the plugin and pass the id of the div containing gallery images 
jQuery("#img_01").elevateZoom({gallery:'products-gallery', cursor: 'pointer', galleryActiveClass: 'active', imageCrossfade: true, loadingIcon: 'http://www.elevateweb.co.uk/spinner.gif'});
//pass the images to Fancybox
jQuery("#img_01").bind("click", function(e) {
var ez = jQuery('#img_01').data('elevateZoom');
jQuery.fancybox(ez.getGalleryList());
return false;
});
Здесь мы видим, что fancybox у нас подключается, но мне нужно к нему добавить навигацию сверху, автоплей и кол-во фото снизу, посредством данного кода:
Код
		jQuery(function($) {
$("a.fancybox-button").fancybox({
//padding: 0,
//fitToView : false,
helpers : {
title : { type : 'inside' }, // options: over, inside, outside, float
buttons : {}
},
afterLoad : function() {
this.title = '<b class="fancyboxCounter">Фото ' + (this.index + 1) + ' из ' + this.group.length + '</b>';
}
});
});
Вопрос в том, как скрестить первое со вторым, чтобы в конечном итоге работал и elevateZoom и Fancybox
*

Филипп Сорокин

  • Завсегдатай
  • 1918
  • 160 / 4
  • разработчик.москва
Re: Как скрестить два плагина js?
« Ответ #1 : 26.02.2016, 10:35:05 »
Плагин вызывается для разных элементов?
*

TommyDBrown

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Re: Как скрестить два плагина js?
« Ответ #2 : 26.02.2016, 10:50:06 »
Какой именно?
*

Филипп Сорокин

  • Завсегдатай
  • 1918
  • 160 / 4
  • разработчик.москва
Re: Как скрестить два плагина js?
« Ответ #3 : 26.02.2016, 10:52:01 »
Какой-нибудь. Повторный запуск плагина с новыми параметрами к чему-то приводит?
*

Wertos

  • Захожу иногда
  • 489
  • 22 / 0
Re: Как скрестить два плагина js?
« Ответ #4 : 26.02.2016, 11:33:09 »
Трудно сказать как сделать, не зная что же в
Код: javascript
ez.getGalleryList()

Но если читануть фак по фансибокс, то можно увидеть в API Methods, такую конструкцию
Код
$.fancybox.open( [group], [options] )

Launch fancyBox, the same as $.fancybox([group], [options])
First parameter can be in various types, examples:
$.fancybox([
{href : 'img1.jpg', title : 'Title'},
{href : 'img2.jpg', title : 'Title'}
]); - array containing objects
В опциях хелперы можно задавать !
Можно попробовать вот так
Код: javascript
jQuery.fancybox(ez.getGalleryList(), {helpers:  { buttons:{} }});
« Последнее редактирование: 26.02.2016, 11:38:38 от Wertos »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться