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

interior

  • Новичок
  • 3
  • 0 / 0
При установке компонента выдает:
Код
        JInstaller::install: Ошибка SQL DB function failed with error number 1064
        You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'TYPE=MyISAM' at line 20 SQL=CREATE TABLE IF NOT EXISTS `jos_easybook` ( `id` int(10) NOT NULL auto_increment, `gbip` varchar(15) NOT NULL default '', `gbname` varchar(40) NOT NULL default '', `gbmail` varchar(60) default NULL, `gbmailshow` tinyint(1) NOT NULL default '0', `gbloca` varchar(50) default NULL, `gbpage` varchar(150) default NULL, `gbvote` int(10) default NULL, `gbtext` text NOT NULL, `gbdate` datetime default NULL, `gbcomment` text, `published` tinyint(1) NOT NULL default '0', `gbicq` varchar(20) default NULL, `gbaim` varchar(50) default NULL, `gbmsn` varchar(50) default NULL, `gbyah` varchar(50) default NULL, `gbskype` varchar(50) default NULL, PRIMARY KEY (`id`) ) TYPE=MyISAM;
        SQL =

        CREATE TABLE IF NOT EXISTS  `jos_easybook` (
                  `id` int(10) NOT NULL auto_increment,
                  `gbip` varchar(15) NOT NULL default '',
                  `gbname` varchar(40) NOT NULL default '',
                  `gbmail` varchar(60) default NULL,
                  `gbmailshow` tinyint(1) NOT NULL default '0',
                  `gbloca` varchar(50) default NULL,
                  `gbpage` varchar(150) default NULL,
                  `gbvote` int(10) default NULL,
                  `gbtext` text NOT NULL,
                  `gbdate` datetime default NULL,
                  `gbcomment` text,
                  `published` tinyint(1) NOT NULL default '0',
                  `gbicq` varchar(20) default NULL,
                  `gbaim` varchar(50) default NULL,
                  `gbmsn` varchar(50) default NULL,
                  `gbyah` varchar(50) default NULL,
                  `gbskype` varchar(50) default NULL,
                  PRIMARY KEY  (`id`)
                ) TYPE=MyISAM;

        Компонент Установить: Ошибка SQL или нечитаемый файл SQL. DB function failed with error number 1064
        You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'TYPE=MyISAM' at line 20 SQL=CREATE TABLE IF NOT EXISTS `jos_easybook` ( `id` int(10) NOT NULL auto_increment, `gbip` varchar(15) NOT NULL default '', `gbname` varchar(40) NOT NULL default '', `gbmail` varchar(60) default NULL, `gbmailshow` tinyint(1) NOT NULL default '0', `gbloca` varchar(50) default NULL, `gbpage` varchar(150) default NULL, `gbvote` int(10) default NULL, `gbtext` text NOT NULL, `gbdate` datetime default NULL, `gbcomment` text, `published` tinyint(1) NOT NULL default '0', `gbicq` varchar(20) default NULL, `gbaim` varchar(50) default NULL, `gbmsn` varchar(50) default NULL, `gbyah` varchar(50) default NULL, `gbskype` varchar(50) default NULL, PRIMARY KEY (`id`) ) TYPE=MyISAM;
        SQL =

        CREATE TABLE IF NOT EXISTS  `jos_easybook` (
                  `id` int(10) NOT NULL auto_increment,
                  `gbip` varchar(15) NOT NULL default '',
                  `gbname` varchar(40) NOT NULL default '',
                  `gbmail` varchar(60) default NULL,
                  `gbmailshow` tinyint(1) NOT NULL default '0',
                  `gbloca` varchar(50) default NULL,
                  `gbpage` varchar(150) default NULL,
                  `gbvote` int(10) default NULL,
                  `gbtext` text NOT NULL,
                  `gbdate` datetime default NULL,
                  `gbcomment` text,
                  `published` tinyint(1) NOT NULL default '0',
                  `gbicq` varchar(20) default NULL,
                  `gbaim` varchar(50) default NULL,
                  `gbmsn` varchar(50) default NULL,
                  `gbyah` varchar(50) default NULL,
                  `gbskype` varchar(50) default NULL,
                  PRIMARY KEY  (`id`)
                ) TYPE=MyISAM;


И удаляла TYPE=MyISAM, и меняла на ENGINE = MyISAM. В общем, делала все, что нашла.
В MySQL никак не сильна, а компонент нужно срочно установить.
Прошу помощи! !
« Последнее редактирование: 20.05.2013, 02:08:18 от interior »
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: SQL-error при установке Easybook Reloaded
« Ответ #1 : 20.05.2013, 01:41:09 »
Версия MySQL какая?
Если удаляли вообще TYPE=MyISAM - на что ругается?
Если сделать ENGINE=MyISAM  DEFAULT CHARSET=utf8 - что будет?
Вы точно после изменений TYPE на ENGINE в XML установщика корректно перепаковывали архив для установки?
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

interior

  • Новичок
  • 3
  • 0 / 0
Re: SQL-error при установке Easybook Reloaded
« Ответ #2 : 20.05.2013, 02:07:41 »
Версия MySQL какая?
Если удаляли вообще TYPE=MyISAM - на что ругается?
Если сделать ENGINE=MyISAM  DEFAULT CHARSET=utf8 - что будет?
Вы точно после изменений TYPE на ENGINE в XML установщика корректно перепаковывали архив для установки?

Видимо таки некорректно перепаковала. Только что с удаленным TYPE=MyISAM установила. Извините за беспокойство!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Не могу распаковать jpa архив сайта Akeeba backup. ajax error

Автор smadkz

Ответов: 4
Просмотров: 1782
Последний ответ 26.12.2020, 15:15:15
от stendapuss
Fatal error: Class 'JDocument' not found

Автор gabiboi

Ответов: 2
Просмотров: 2352
Последний ответ 04.09.2020, 14:39:07
от svetka_777
simpleform2 ошибка ajax error в Google chrome

Автор safronoff343

Ответов: 1
Просмотров: 1176
Последний ответ 05.06.2020, 20:36:42
от safronoff343
[Решено] Проблема с авторизацией Invalid Token

Автор treX

Ответов: 100
Просмотров: 96494
Последний ответ 06.10.2019, 16:55:45
от PaLyCH
Ошибка Fatal error: Allowed memory size of 73400320 bytes exhausted

Автор Andre109

Ответов: 1
Просмотров: 2108
Последний ответ 03.12.2018, 01:29:56
от voland