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

smivan85

  • Осваиваюсь на форуме
  • 47
  • 3 / 0
Переношу ряд тестовых сайтов с мастерхоста на valuehost.
Все основные материалы (статьи, тексты ссылок меню) стали псевдографикой (подробнее о том, что такое псевдографика: " Рљ 2020 Рі. энергоемкость СЌРєРѕРЅРѕРјРёРєРё Р РѕСЃСЃРёРё должна сократиться РЅР° 40%. Это РіРѕРІРѕСЂРё")
зато тексты, по случаю вписанные в шаблон, в самописные модули, или тексты, задающиеся из language или файла конфигурации - всё нормально.
Валюехостовская поддержка предлагает перенести площадку на сервак с 5й версией мускулом. Сейчас видимо 4.
Про мастерхост не знаю, вот из заголовка базы данных
"
-- Версия сервера: 5.0.67
-- Версия PHP: 4.4.6
"

Инфу по этой проблеме искал, слишком много, подскажите пожалуйста что именно рыть.
Спасибо.
*

smivan85

  • Осваиваюсь на форуме
  • 47
  • 3 / 0
*

smivan85

  • Осваиваюсь на форуме
  • 47
  • 3 / 0
Прикольно. И всёже мне не верится в то, что с моей джумлой случилось что-то необычное. Не смотря на то, что никто в этой проблеме, похоже, нее разумеет, она заключается всего-лишь в конфликте кодировок разных версий MySQL. Вот только что делать? Пройдёт время, потом ещё время, потом ещё немножко времени, и ответ откроется сам...
*

oleggrz

  • Захожу иногда
  • 435
  • 76 / 3
  • Только начал учиться.
Посмотрите в PhpMyAdmin таблица jos_menu в какой кодировке стоит - надо win-1251, а у вас похоже в utf-8. Вообще просмотрите все таблицы, возможно при переносе в некоторых занеслась не та кодировка.
*

smivan85

  • Осваиваюсь на форуме
  • 47
  • 3 / 0
Спасибо, прикол в том, что база данных на валюехосте вообще не содержит возможности прописать кодировку отдельно таблицам и строкам.
*

smivan85

  • Осваиваюсь на форуме
  • 47
  • 3 / 0
Проблема решилась действительно переносом контента на новый сервак с более новой версией MySQL (блин, или PhpMyAdmin...). Причём, всё работало правильно только при том условии, что совместимость при импорте была поставлена в utf-8.
Всем спасибо.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Проблема с БД после переезда на новый хостинг

Автор dimitriopolus

Ответов: 6
Просмотров: 22496
Последний ответ 03.01.2018, 23:42:41
от vikup34
Кодировка Joomla lavra edition 2008

Автор evgen22

Ответов: 12
Просмотров: 6207
Последний ответ 22.08.2015, 14:26:24
от SeBun
кодировка и .htaccess

Автор Cmac

Ответов: 8
Просмотров: 16693
Последний ответ 13.01.2014, 18:52:39
от icedfox
Ошибка при переносе на новый хост

Автор mo0f

Ответов: 3
Просмотров: 3059
Последний ответ 15.04.2013, 09:59:46
от Werber
Хостинг обновляет PHP до версии 5.3.10

Автор ASDF

Ответов: 5
Просмотров: 5734
Последний ответ 19.04.2012, 11:23:19
от SK