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

AlkisTer

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Сначала задача: нужно отобразить некую таблицу БД(точнее её определённые поля), и для определённых пользователей свои записи (SQL  условие, я понимаю)
У меня два вопроса: можно отобразить её стандартной таблицей в редакторе материалов ( у меня при создании таблицы сплошные крякозябры, ничего не понять). Если да, то учебник поэтому делу есть? И можно исправить крякозябры?

Второй, альтернативный компонент отбражения таблиц есть?
*

AlkisTer

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Re: Вопрос о отображении таблиц.
« Ответ #1 : 10.08.2012, 09:50:19 »
Никто не поможет? :)
*

AlkisTer

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Re: Вопрос о отображении таблиц.
« Ответ #2 : 13.08.2012, 17:25:51 »
Хорошо. С помощью компонента Jumi я отобразил php код вывода записей таблице.
 Всё работает, только исчезает всё меню и появлются восемь надписей "ОШИБКА ПРИ ЗАГРУЗКЕ МОДУЛЯ". Из-за чего это происходит?

 Так же происходит если вставлять php код в действие после обработки Chronoform формы.
*

AlkisTer

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Re: Вопрос о отображении таблиц.
« Ответ #3 : 15.08.2012, 10:38:48 »
Разобрался в чём дело: я делал, как в прммере с подключением базы данных. Выключил подключение к БД и всё хорошо работает. Если кому надо выводить таблицу БД (и таблицу записей chronoform в частности), вот мой вариант решения:

1. Скачиваешь/устанавливаешь мод JUMI
2. создаёшь новый материал примерно такого содержания:

<?php
$sql = "SELECT * FROM `jos_chronoforms_event_new` LIMIT 0, 30 ";
$res = mysql_query($sql);
echo "<TABLE>";
//шапка таблицы
echo "<TR>
<TD><blockquote> ФИО отправителя</blockquote></TD>
<TD><blockquote> Объект </blockquote></TD>
<TD><blockquote>  Адресс объекта </blockquote></TD>
<TD><blockquote>  Дата события </blockquote></TD>
<TD><blockquote>  Случившееся ситуация </blockquote></TD>
<TD><blockquote>  Подробное описание </blockquote></TD>
";
// сама таблица
while ($row = mysql_fetch_array($res))
 {
 echo "  <TR>
<TD><blockquote> $row[name]</blockquote></TD>
<TD><blockquote> $row[object] </blockquote></TD>
<TD><blockquote>  $row[adress] </blockquote></TD>
<TD><blockquote>  $row[date_4] </blockquote></TD>
<TD><blockquote>  $row[check0] </blockquote></TD>
<TD><blockquote>  $row[Opis] </blockquote></TD>"; }
echo "</TABLE>" ;
 ?>
3. Создаёшь пункт меню с ссылкой на этот материал (либо модулем выводишь).

Дальше буду делать постраничный вывод и разделение записей для разных пользователей.
« Последнее редактирование: 15.08.2012, 11:41:48 от AlkisTer »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вопрос при переходе на https/ Проблема с внутренними ссылками

Автор krot

Ответов: 4
Просмотров: 2039
Последний ответ 06.02.2018, 09:21:33
от krot
Вопрос о правильности разметки тегами на странице

Автор dpy1995

Ответов: 10
Просмотров: 6358
Последний ответ 09.01.2018, 12:49:25
от kungurskiy
Re: Изменение таблиц базы данных

Автор ZAlex60

Ответов: 4
Просмотров: 1465
Последний ответ 23.09.2016, 09:57:14
от ZAlex60
вопрос по использованию FireBug

Автор rkorkin

Ответов: 5
Просмотров: 3948
Последний ответ 06.08.2016, 17:34:23
от Saltanat
Вопрос по Joomla Platform 12.2.0 Stable

Автор ator1812

Ответов: 0
Просмотров: 1560
Последний ответ 12.07.2015, 21:51:55
от ator1812