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

yrygvay

  • Завсегдатай
  • 1293
  • 36 / 3
MySQL база даннх К2
« : 19.01.2013, 20:44:19 »
Приветствую.
Есть два сайта с к2 одинаковой версии. Стоит задача объединить их в один сайт.

Пробовал импорт таблицы к2 с материалами, но он криво импортируется в csv.

Подскажите варианты решения, может кто сталкивался! *DRINK*
Смотрю....
*

waterfly

  • Захожу иногда
  • 83
  • 0 / 0
Re: MySQL база даннх К2
« Ответ #1 : 19.01.2013, 23:18:15 »
На днях прикупил капризную программку импорта/экспора материалов k2 в csv и из csv.
Перенес сайт. При желании могу поделиться.
*

yrygvay

  • Завсегдатай
  • 1293
  • 36 / 3
Re: MySQL база даннх К2
« Ответ #2 : 20.01.2013, 13:32:23 »
тоже купил этот импорт для к2 (наверно тот-же)

Пробовал экспортировать им, подскажи какие разделители ставил для разбития по полям в csv ?
Смотрю....
*

waterfly

  • Захожу иногда
  • 83
  • 0 / 0
Re: MySQL база даннх К2
« Ответ #3 : 20.01.2013, 16:46:31 »
Примерно такой синтаксис. 'category', 'introtext', 'fulltext', 'image',
По другому никак мои эксперименты не получались. Самое печальное, что если в импортируемом cvs есть изображение, например <img alt="image" src="images/img-games/image_14.jpg" width="430">, то cvs не импортируется или ломает структуру таблицы _k2_items из за кавычек.

В общем программа нужная, но для переноса скорее не подойдет. Имхо скриптом менять id материалов в переносимой таблице и спокойно заливать в базу.

По крайней мере я так вижу ситуацию.

А я в обще остановился на парсере. За вечер получил одну гигантскую таблицу _k2_items из материалов своих сайтов на разных движках.
*

yrygvay

  • Завсегдатай
  • 1293
  • 36 / 3
Re: MySQL база даннх К2
« Ответ #4 : 22.01.2013, 19:19:50 »
Сам думаю спарсить ... но просто парсить свои-же сайты рука не поднимается)))))
Смотрю....
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

База данных растет с геометрической прогрессией

Автор xvx

Ответов: 9
Просмотров: 10608
Последний ответ 28.04.2014, 07:41:29
от jurassik
MySQL ошибка при добавлении статьи в К2

Автор amasbee

Ответов: 0
Просмотров: 984
Последний ответ 31.03.2013, 04:29:44
от amasbee
База данных K2

Автор andreiz

Ответов: 3
Просмотров: 2217
Последний ответ 10.02.2013, 22:57:48
от andreiz
Word -> MySQL / K2

Автор chilly_bang

Ответов: 12
Просмотров: 1570
Последний ответ 17.12.2012, 19:47:20
от chilly_bang