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

mondee

  • Осваиваюсь на форуме
  • 15
  • 1 / 0
Формирую таблицу таким кодом:
Код

$tableheader[] = '<center><a class="nohref" title="'.$VM_LANG->_('CLUB_NUM').'">'.$VM_LANG->_('CLUB_KRAT_NUM').'</center>';
// ... тут несколько строк пропущено
$tableheader[] = '<center><a class="nohref" title="'.$VM_LANG->_('CLUB_O').'">'.$VM_LANG->_('CLUB_KRAT_O').'</center>';

$table =& new HTML_Table('width="100%"');

$table->addRow( $tableheader, 'class="sectiontableentry5"', 'td', true );

foreach( $products as $product ) {

foreach( $product as $attr => $val ) {
// Using this we make all the variables available in the template
// translated example: $this->set( 'product_name', $product_name );
$this->set( $attr, $val );
}

$data[$row][] = '<center>'.$product['club_num'].'</center>';
// ... тут несколько строк пропущено
$data[$row][] = '<center>'.$product['club_o'].'</center>';

$row++;
 
}
$i=1;
foreach($data as $key => $value) {

$table->addRow( $data[$key], 'class="sectiontableentry'.$i.'"', 'td', true );
$i = $i == 1 ? 2 : 1;
}

echo $table->toHtml();


Соответственно заголовок таблицы имеет класс "sectiontableentry5", а каждая строка в таблице чередует "sectiontableentry1" и "sectiontableentry2"

В базе данных имею поле club_div, в котором есть значения двух видов "Z" и "V"
Сейчас задался идеей, чтобы каждая строка имела свой класс в зависимости от значения поля club_div, т.е. "sectiontableentry1" если club_div=Z и "sectiontableentry2" если club_div=V
Что мне поменять в коде, чтобы это получилось?
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Код: php
if ($club_div == Z) {
$class = 'sectiontableentry1';
} else {
$class = 'sectiontableentry2';
}
и подставлять куда нужно
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

mondee

  • Осваиваюсь на форуме
  • 15
  • 1 / 0
Я примерно так и делал, вот что у меня получалось:
Код
$tableheader[] = '<center><a class="nohref" title="'.$VM_LANG->_('CLUB_NUM').'">'.$VM_LANG->_('CLUB_KRAT_NUM').'</center>';
// ... тут несколько строк пропущено
$tableheader[] = '<center><a class="nohref" title="'.$VM_LANG->_('CLUB_O').'">'.$VM_LANG->_('CLUB_KRAT_O').'</center>';

$table =& new HTML_Table('width="100%"');

$table->addRow( $tableheader, 'class="sectiontableentry5"', 'td', true );

foreach( $products as $product ) {

foreach( $product as $attr => $val ) {
// Using this we make all the variables available in the template
// translated example: $this->set( 'product_name', $product_name );
$this->set( $attr, $val );
}

$data[$row][] = '<center>'.$product['club_num'].'</center>';
// ... тут несколько строк пропущено
$data[$row][] = '<center>'.$product['club_o'].'</center>';

$row++;
   if ($product['club_div'] == Z ) {
           $class = 'sectiontableentry1';
           } else {
           $class = 'sectiontableentry2';
        }
}

foreach($data as $key => $value) {

$table->addRow( $data[$key], 'class="'.$class.'"', 'td', true );

}

echo $table->toHtml();

но в таком случае $class принимает значение последнего цикла выборки товара, и соответственно все строки имеют один класс :(

Может я не туда засовываю этот if?

Я думаю надо массив какой-то $class мутить чтоб для каждой $data[$key] была своя $class. Только как это сделать?
« Последнее редактирование: 10.09.2011, 08:52:32 от mondee »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Ошибка #1050 при переносе базы данных на хостинг

Автор Ksen

Ответов: 7
Просмотров: 24781
Последний ответ 16.03.2020, 17:47:29
от Petrovich
Передача данных в форму при нажатии на ссылку

Автор usmdamir

Ответов: 4
Просмотров: 1637
Последний ответ 26.07.2017, 09:40:22
от usmdamir
Re: Изменение таблиц базы данных

Автор ZAlex60

Ответов: 4
Просмотров: 1465
Последний ответ 23.09.2016, 09:57:14
от ZAlex60
Ввод данных на сайте – подстановка их в текст. документ

Автор Plazmodina

Ответов: 4
Просмотров: 2706
Последний ответ 10.09.2015, 15:20:44
от DeKajper
[Решено] Права администратора или создание нового администратора через базу данных

Автор Savior

Ответов: 8
Просмотров: 7542
Последний ответ 24.10.2014, 20:01:45
от AlekVolsk