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

forzi

  • Захожу иногда
  • 81
  • 0 / 0
 :( Господа. Проблема вот в чем, на сайте под управлением CMS Joomla версии 1, 5 приключилась такая беда. Больше месяца им не занимались - причина на то была и весьма веская, он вполне нормально работал и новые пользователи спокойно и безпроблемно на нем регистрировались. Но дня четыре назад один из пользователей сообщил, что пропала регистрация. Вернее все поля для регистрации есть, они заполняются, но при нажатии кнопки "Зарегистрировать" ничего не происходит. В Chrome открыл консоль и увидел такое:
Код
Uncaught SyntaxError: Unexpected identifier index.php:2019
Uncaught TypeError: Object [object Object] has no method 'addEvent' hover.js:1
(anonymous function) hover.js:1
(anonymous function) hover.js:1
returns mootools.js:21
(anonymous function) mootools.js:21
(anonymous function) mootools.js:50
Element.Methods.Events.fireEvent mootools.js:50
(anonymous function) mootools.js:59
(anonymous function) mootools.js:59
returns

Я понимаю, что что-то с Ява-скриптами - но не могу понять причину и где ковырять, да и какую отвертку для этого надо.... Подскажите - что лечить - сайт или мою голову?)))
*

forzi

  • Захожу иногда
  • 81
  • 0 / 0
Что то молчат специалисты. Нет ни одного ответа. Или никто не знает, что произошло? Тогда немного расширю вопрос. При просмотре в консоли выяснил, что проблема с hover.JS вот что выдало в репорте:
Код
 window.addEvent('domready', function() {
(((/// Вот именно тут показывает ошибку, ссылаясь на отсутствие или сбой addEvent///)))
            var list = $$('#left a.mainlevel,#left ul.menu li a,#right a.mainlevel,#right ul.menu li a');
              list.each(function(element) {
                var fx = new Fx.Styles(element, {duration:350, wait:false, transition: Fx.Transitions.Quad.easeInOut});

            element.addEvent('mouseenter', function(){
                  fx.start({
 
                 'padding-left': 35,        
                 'color': '#222222'

                 });
            });


            element.addEvent('mouseleave', function(){
                 fx.start({

                   'padding-left': 10,        
                   'color': '#222222'
                  });
                });
            });

           var list = $$('ul.menu li li a, a.sublevel');

          list.each(function(element) {
         var fx = new Fx.Styles(element, {duration:350, wait:false,transition: Fx.Transitions.Quad.easeInOut});

                   element.addEvent('mouseenter', function(){
                   fx.start({

                   'padding-left': 35,
                    'color': '#888'

          });
          });

 element.addEvent('mouseleave', function(){
fx.start({

                   'padding-left': 10,
                   'color': '#999'
           });
    });
      });


               var list = $$('a.contentpagetitle,.contentheading ' );

                  list.each(function(element) {
                  var fx = new Fx.Styles(element, {duration:500, wait:false});
                  element.addEvent('mouseenter', function(){
                  fx.start({
                       'color': '#ffffff'
});
});
element.addEvent('mouseleave', function(){
fx.start({
        'color': '#3a3225'
});
});

});
var list = $$('#header_topmenu a');
list.each(function(element) {
var fx = new Fx.Styles(element, {duration:500, wait:false});
element.addEvent('mouseenter', function(){
fx.start({        
         'color': '#efefef'
});
});
element.addEvent('mouseleave', function(){
fx.start({            
        'color': '#000000'
});
});
});


});


function scrollToTop(){
  scrollBy(0,-1500) ;
}

function scrollToTop(){
for (var i=0;i<1500;i++){
    scrollBy(0,-15) ;
  }
}

Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться