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

slovoblud

  • Осваиваюсь на форуме
  • 29
  • 0 / 0
  • Починяю примуса
В продолжение темы про цену атрибута решил что проще всего будет сформировать MySQL запрос к базе данных и вытащить оттуда цену атрибута по product_id. В принципе все данные для этого есть:
Таблица атрибутов называется: ybc9a_jshopping_products_attr вынимать данные нужно из поля price по полю product_id само значение product_id в файле components/com_jshopping/templates/default/product/product_default.php можно получить при помощи конструкции
Код
$this->product->product_id;
Но вот как сформировать сам запрос и как вывести полученные данные в цикле? На простом php я бы еще написал, но как сделать чтобы запрос соответствовал архитектуре самого движка? В общем если есть знатоки  php MySQL помогите составить правильный запрос. :'(
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
т.е. сам MySQL запрос вы знаете какой надо, а проблема как верно его написать используя апи Joomla? или вы и сам MySQL запрос не знаете какой надо? а в той теме, куда вы ссылаетесь, я честно говоря вообще не понял чего итого вы добиться хотите.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

slovoblud

  • Осваиваюсь на форуме
  • 29
  • 0 / 0
  • Починяю примуса
Мне нужно вывести возле каждого атрибута его цену. Чтобы пользователь видел сразу 2 цены. (например оптом и в розницу)
В карточке товара вывести почти получилось. В файле components/com_jshopping/templates/default/product/product_default.php в месте где мне нужно выводить цены атрибутов я вставил следующий код:
Код
<?php 
         $id_prod=$this->product->product_id;
//1. Создадим экземпляр класса
$db =& JFactory::getDBO();
//2. Создадим запрос к базе данных, в данном случае мы выбираем первую статью
$q = "SELECT price FROM ybc9a_jshopping_products_attr WHERE product_id='$id_prod'";
//3. Установим этот запрос в экземпляр класса работы с базами данных
$db->setQuery($q);
//4. Выполним запрос и получим данные
$data_array = $db->loadResultArray();

$schot = count($data_array);
for($i=$schot-1;$i>=0;$i--)
{
echo $data_array[$i]."<br />";
}
?>
Проблема в том что этот код выводит только цифры с четырьмя знаками после запятой. Пробую округлять результат при помощи round() но он почему то округляет до целого числа, а хотелось бы чтобы округлял до двух знаков после запятой. Также проблема в том что не выводится валюта. Если можете подскажите как ее вывести отдельной переменной. И наконец также нужно вывести цену каждого атрибута в списке товаров в категории. Не знаю подойдет для этого тот код что выше или нет еще не пробовал.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
вывод цены - echo formatprice(цена)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как передать данные из характеристики в поле формы Balboa Forms?

Автор Hugo

Ответов: 3
Просмотров: 1546
Последний ответ 07.04.2024, 22:38:50
от Vastriet
Добавление атрибутов к товарам через MySQL

Автор viteg

Ответов: 3
Просмотров: 1144
Последний ответ 29.03.2015, 00:46:03
от viteg
Хранение данных о характеристиках в MySQL

Автор neonox

Ответов: 1
Просмотров: 1059
Последний ответ 03.03.2014, 22:58:29
от dmitry_stas
Массовое изменение цен для категории в MySQL

Автор Chumanju

Ответов: 7
Просмотров: 2663
Последний ответ 24.07.2012, 21:28:17
от nevigen