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

Kilexus

  • Новичок
  • 1
  • 0 / 0
Продвинутый SQL в статье
« : 22.05.2013, 01:28:11 »
Здравствуйте,
есть SQL-таблица с многими полями.
Как сделать статью, в которой значения одного из полей (например, фамилии сотрудников) шли бы листом, типа:
1. Иванов
2. Петров
... ....
56. Сидоров

при этом сами фамилии тянулись бы из таблицы?
Более интересно -- можно ли сделать так, чтобы эти фамилии посвечивались как ссылки, при нажатии на которые происходил бы переход на новую страницу, где были бы также указаны все сопутствующие поля? (например, Сидоров, его зарплата, адрес, домашнее животное...)

 !
*

SmokerMan

  • Гуру
  • 5290
  • 720 / 26
Re: Продвинутый SQL в статье
« Ответ #1 : 22.05.2013, 12:19:12 »
в чем продвинутость то?)
Для реализации данного функционала нужно написать свой компонент + плагин или модуль
Необходимый порог вхождения - знания php, синтаксис запросов SQL, html/css, api Joomla
Если этих знаний нет, то проще обратиться в коммерческий раздел
"Просто так" данный функционал сделать не получется
« Последнее редактирование: 22.05.2013, 12:31:46 от SmokerMan »
*

rsa_m

  • Захожу иногда
  • 254
  • 22 / 0
Re: Продвинутый SQL в статье
« Ответ #2 : 22.05.2013, 12:36:11 »
У меня есть плагин ( https://github.com/rsam/plg_sqlcon ), который позволяет тянуть из SQL базы любое значение.
Как с ним работать можно почитать здесь или в PDF который лежит на GIT

Если его немного допилить то можно выводить и все значения указанной колонки списком и как ссылки. Он очень простой внутри, допилить труда не составит при знании PHP.
*

SmokerMan

  • Гуру
  • 5290
  • 720 / 26
Re: Продвинутый SQL в статье
« Ответ #3 : 22.05.2013, 12:47:11 »
Плагин тут не поможет
Цитировать
можно ли сделать так, чтобы эти фамилии посвечивались как ссылки, при нажатии на которые происходил бы переход на новую страницу, где были бы также указаны все сопутствующие поля?
это надо делать компонентом
*

Fedor Vlasenko

  • Живу я здесь
  • 3845
  • 733 / 7
  • https://fedor-vlasenko.web.app
Re: Продвинутый SQL в статье
« Ответ #4 : 22.05.2013, 12:55:29 »
Хех. А зачем все это.
Делаем материалы в категории сотрудники:
1. Иванов
2. Петров
... ....
56. Сидоров
Выводим список категории сотрудники
*

rsa_m

  • Захожу иногда
  • 254
  • 22 / 0
Re: Продвинутый SQL в статье
« Ответ #5 : 22.05.2013, 13:08:04 »
Хех. А зачем все это......

Это Да. Но как вытащить из таблицы SQL значения? Если это таблица user - то да, сработает. а если произвольная таблица !?
*

SmokerMan

  • Гуру
  • 5290
  • 720 / 26
Re: Продвинутый SQL в статье
« Ответ #6 : 22.05.2013, 13:08:31 »
а если сотрудников 100500 будет? заипется создавать)
Это Да. Но как вытащить из таблицы SQL значения? Если это таблица user - то да, сработает. а если произвольная таблица !?
какая разница какая таблица? Запрос можно любой сделать
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как прописать позицию модуля в статье

Автор Silverstreet

Ответов: 16
Просмотров: 5934
Последний ответ 20.08.2013, 06:24:03
от Dmitriy M
Текст в модуле и статье меняется на ссылку

Автор wanderbild

Ответов: 3
Просмотров: 1395
Последний ответ 12.04.2013, 23:51:51
от wanderbild
Как вывести модуль в конкретной статье

Автор Maksimcase

Ответов: 8
Просмотров: 2765
Последний ответ 10.03.2013, 12:16:41
от sachek
Как привязать статью к статье?

Автор Аля

Ответов: 2
Просмотров: 1344
Последний ответ 17.02.2013, 01:28:17
от Аля
Проблема с отображением картинок в статье

Автор Rio74

Ответов: 9
Просмотров: 1670
Последний ответ 29.09.2012, 00:29:58
от sergoguga