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

mira3a

  • Новичок
  • 6
  • 0 / 0
Доброго времени суток! Столкнулся с такой проблемой.

Отправляю данные из статьи K2 через форму RSForm (Название статьи).
Появилась задача отправлять через эту же форму дополнительные поля, но возникла проблема!
при запросе к БД через форму RSForm
Код
//<code>
$db = JFactory::getDbo();
$db->setQuery("SELECT extra_fields FROM jos_k2_items WHERE id ='".$this->item->id."'");
return $db->loadResult();
}
//</code>

приходит в ответ вот такая шляпа

Код
[{"id":"1","value":"122951"},{"id":"2","value":"400306"},{"id":"3","value":"\u0421\u0442\u0430\u043b\u044c, \u043d\u0435\u0440\u0436\u0430\u0432\u0435\u044e\u0449\u0430\u044f \u0441\u0442\u0430\u043b\u044c"},{"id":"4","value":"370 \u043a\u0433"},{"id":"5","value":"1850x830x2700"},{"id":"6","value":""},{"id":"7","value":"1"}]

понимаю, что тут идут доп. поля по id, но как их разделить не знаю...
ломаю голову 2 день, как это сделать(((((  или что добавить в код выше что бы они приходили нормально?
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
*

mira3a

  • Новичок
  • 6
  • 0 / 0
Можно более подробно? мне нужно сделать так, что бы выводилось по id каждое из полей

и получался результат не
[{"id":"1","value":"122951"},{"id":"2","value":"400306"},{"id":"3","value":"\u0421\u0442\u0430\u043b\u044c, \u043d\u0435\u0440\u0436\u0430\u0432\u0435\u044e\u0449\u0430\u044f \u0441\u0442\u0430\u043b\u044c"},{"id":"4","value":"370 \u043a\u0433"},{"id":"5","value":"1850x830x2700"},{"id":"6","value":""},{"id":"7","value":"1"}]

а

Артикул: 122951
Цена: 400306

и т.д.
*

mira3a

  • Новичок
  • 6
  • 0 / 0
Огромное спасибо Arkadiy.

Все сделал. код подставляем. и выводит нужное значение по артикулу

Код
//<code>
$db = JFactory::getDbo();
$db->setQuery("SELECT extra_fields FROM jos_k2_items WHERE id ='".$this->item->id."'");
$dop=$db->loadResult();
$obj=json_decode($dop);
return $obj[0]->value;
//</code>
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Дополнительное поле Ссылка / Как изменить текст?

Автор designerandrey

Ответов: 6
Просмотров: 998
Последний ответ 20.07.2020, 16:56:57
от designerandrey
Заброс в БД для массового добавления значений в доп. поле k2

Автор lgmax

Ответов: 2
Просмотров: 976
Последний ответ 16.09.2019, 11:33:11
от beliyadm
Как включить полноценный редактор в доп. поле?

Автор bybus

Ответов: 0
Просмотров: 1084
Последний ответ 24.11.2017, 13:28:18
от bybus
K2 убрать поле InfoText

Автор Dusk09

Ответов: 0
Просмотров: 974
Последний ответ 26.10.2017, 12:35:14
от Dusk09
1 доп. поле в нескольких групах

Автор terr

Ответов: 0
Просмотров: 923
Последний ответ 06.10.2016, 14:43:19
от terr