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

evsmusic

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Всем привет! Пишу модуль поиска для вирта, чтобы при вводе артикула, мне выводиля искомый товар в внизу у него появлялись товары, которые являются дочерними от искомого товара. С этим разобрался. Мозг вспух, и что-то так и не могу догнать, как теперь сформировать запрос, чтобы при поиске дочернего товара так же внизу появлялся список родительского товара.

Итак, подробнее: в базе в таблице #__vm_product есть колонка под названием `product_parent_id`, в ней умолчанием забивается айди родительского товара. Тоесть есть товары с айдихами: 10,11,12,13,14,15, 10 - родительский, и его айди пишется в `product_parent_id` у дочерних товаров. Тоесть, 11,12,13 и тд имеют `product_parent_id = 10`, соответственно 10 - не имеет parent_id, точнее он просто НУЛЬ .
тут все просто, чтобы получить детей родителя - 10, надо тупо сделать так -
Код
SELECT `product_sku` FROM `#__virtuemart_product` WHERE product_parent_id =" . $result->virtuemart_product_id
- в $result собственно выбирается искомая айдиха товара связанная с его артикулом.

Теперь вопрос - что надо сформировать чтобы у детей показать остальных детей данного родителя и самого родителя.
*

evsmusic

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
В общем кому интересно, решил временно текущую проблема следующим, далеко не самым красивым образом, но пока работает:

Код

<?php

$db =& JFactory::getDBO();
//выбираем id родительского товара
$qurery1 = "SELECT product_parent_id
 FROM #__virtuemart_products
WHERE product_parent_id != 0
  AND virtuemart_product_id =".$result->virtuemart_product_id ."";
 
$db->setQuery($qurery1);

$childs_ch = $db->loadResultArray();

$parent_id = $childs_ch[0];

//если айдишка родительского товара отстутствует, тоесть в запрос пришел сам родитель, то надо вывести всего лишь детей
if(is_null($parent_id)){
$query2 = "SELECT product_sku FROM #__virtuemart_products
WHERE product_parent_id = ".$result->virtuemart_product_id ."";
 
$db->setQuery($query2, 0, $limit);
$childs = $db->loadObjectList();

}else{

//в ином случае выводим все что имеем: все дочение товары относительно папы текущего товара, самого папу, и себя
$query2 = "SELECT product_sku,virtuemart_product_id FROM #__virtuemart_products
  WHERE product_parent_id = ".$result->virtuemart_product_id ."
OR product_parent_id = ".$parent_id."        
OR virtuemart_product_id = ".$parent_id."
 ";
 
$db->setQuery($query2, 0, $limit);
$childs = $db->loadObjectList();
}

echo '<p><div style="display: inline-block;margin-top: 12px;">Из этой же категории: ';
echo '<span>';

if($childs){
foreach($childs as $key => $row){
$childlink = "index.php?option=com_virtuemart&view=productdetails&virtuemart_product_id=" .$row->virtuemart_product_id ."";
$chlink = htmlspecialchars(stripslashes($childlink));

?><a href="<?=$childlink?>"><?=$row->product_sku?></a> || <?php
#if($result->text){echo $result->text;}
}
}else{
echo 'Нет совпадений</p>';
}
echo '</span>';
echo '</div>';

?>


Минусы этой конструкции -
1: Не выводится краткое описание родителя к детям;
2: По желанию можно убрать вывод самого себя в дочерних товарах.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Исправить подтягивание значений контактов клиента из базы SQL

Автор Nessy74

Ответов: 5
Просмотров: 1021
Последний ответ 31.12.2015, 07:05:16
от Филипп Сорокин
Изменить запрос поиска mod_virtuemart_search

Автор Tokyo

Ответов: 1
Просмотров: 1397
Последний ответ 06.06.2013, 02:03:57
от fsv
Поиск по полям базы данных

Автор valensy

Ответов: 1
Просмотров: 1243
Последний ответ 08.09.2012, 21:39:45
от flyingspook
SQL запрос

Автор Infosakh

Ответов: 6
Просмотров: 2003
Последний ответ 29.05.2012, 21:06:09
от asimo
Отображение количества товаров в категориях. Требуется помощь по изменению не дефолтового модуля кат

Автор mmontana

Ответов: 0
Просмотров: 1203
Последний ответ 22.01.2010, 02:13:55
от mmontana