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

юрий 009

  • Захожу иногда
  • 341
  • 5 / 1
Доброго времени суток.
подскажите пожалуйста как сделать скроллинг к сопутствующим товарам?
с помощью кнопки ...
это при условии, если есть сопутствующие товары в самом товаре (если нет, то и нет кнопки)
*

юрий 009

  • Захожу иногда
  • 341
  • 5 / 1
Re: Скроллинг к сопутствующим товарам
« Ответ #2 : 23.02.2015, 11:41:53 »
скроллинг я сделал, а как сделать условие если нет сопутствующих то и нет кнопки
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Скроллинг к сопутствующим товарам
« Ответ #3 : 23.02.2015, 12:49:10 »
if (count($this->related_prod))
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

юрий 009

  • Захожу иногда
  • 341
  • 5 / 1
Re: Скроллинг к сопутствующим товарам
« Ответ #4 : 23.02.2015, 12:56:34 »
спасибо
*

юрий 009

  • Захожу иногда
  • 341
  • 5 / 1
Re: Скроллинг к сопутствующим товарам
« Ответ #5 : 23.02.2015, 15:14:05 »
может кому-то понадобится:
Вариант 2
в файле
www\SITE\components\com_jshopping\templates\ваш темплете\product\product_default.php
добавляем:
Код
<?php if (count($this->related_prod)) {?>
<div id="skroling5">
  <ul>
    <li><a href="#top5"><?php echo _JSHOP_RELATED_PRODUCTS?>   </a></li>
  </ul>
</div>
<?php }?>
в файле
www\SITE\components\com_jshopping\templates\ваш темплете\product\related.php
меняем или добавляем:
Код
<div class="related_header">  <h3 id="top5">  <?php echo _JSHOP_RELATED_PRODUCTS?>   </h3> </div>
но у меня пока еще не получилось приделать плавный скроллинг :(
« Последнее редактирование: 23.02.2015, 15:40:21 от юрий 009 »
*

shurakana

  • Давно я тут
  • 792
  • 50 / 6
Re: Скроллинг к сопутствующим товарам
« Ответ #6 : 23.02.2015, 15:19:31 »
Если у тебя два или три товара сопутствующих, мне кажется скроллинг не нужен, поэтому стоит определить кол-во товара которое влезает в блок без прокрутки, а когда их больше то уже выводить скролл

И Измени заголовок, на <h3>
« Последнее редактирование: 23.02.2015, 15:25:59 от shurakana »
Эта подпись отображается внизу каждого Моего сообщения. Я также могу использовать BB код и смайлы.
*

юрий 009

  • Захожу иногда
  • 341
  • 5 / 1
Re: Скроллинг к сопутствующим товарам
« Ответ #7 : 23.02.2015, 15:50:33 »
Код
(function($){
   $(document).on('click', 'a[href^=#]', function () {
        $('html, body').animate({ scrollTop:  $('a[name="'+this.hash.slice(1)+'"]').offset().top }, 1000 );
        return false;
    });
})(jQuery);
куда пристроить этот код?
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться