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

Zuev

  • Захожу иногда
  • 211
  • 15 / 1
  • В дальнем плавании
Задача: Выводится каталог чего-либо (например фантиков ^-^). В каталоге указано название фантика его фотография, краткое описание,  количество коментариев и рейтинг каждого фантика. И все это в виде списка. Когда мыхой тыкаешь по конкретному фантику открывается полное описание возможность голосования и комментирования. Стандартные модули не подходят, поэтому все пишится под эту конкретную задачу. Вопрос: как в этот список вывести райтинг каждого "фантика". Система голосования : cdajaxvote на joomle 1.5.

Например для вывода количества комментариев используется код:<?php
 $comments = '/home/?/public_html/?/components/com_jcomments/jcomments.php';
 $id = 49;
    require_once($comments);
    $count = JComments::getCommentsCount($id, 'com_content');
  echo "$count";
?>

хотелось что-то вроде этого, ну или образец запрос в БД
« Последнее редактирование: 12.11.2008, 19:24:13 от Zuev »
*

Zuev

  • Захожу иногда
  • 211
  • 15 / 1
  • В дальнем плавании
плагин cdajaxvote использует стандартную таблицу jos_content_rating c полями данных content_id, rating_sum, rating_count, lastip
*

Zuev

  • Захожу иногда
  • 211
  • 15 / 1
  • В дальнем плавании
вот что получилось, проверенно на joomla 1.5, работает

<?php
$db = & JFactory::getDBO();
$article_id = 49; //id статьи у меня заранее ивестен поэтому ставлю его сразу
$query = 'SELECT *' . ' FROM #__content_rating' . ' WHERE content_id = ' . (int) $article_id;//делаем выборку в базе по id статье
$db->setQuery($query);
$rating = $db->loadObject(); //получаем все поля данных (content_id, rating_sum, rating_count и lastip) из таблицы jos_content_rating для отобранного объекта
$summa_balov = $rating->rating_sum;//берем из $rating параметр rating_sum (общее количество баллов)
$sgolosov = $rating->rating_count;//берем из $rating параметр rating_count (общее количество проголосовавших)
$result = ceil($summa_balov / $sgolosov); //дели баллы на голоса и округляем в большую сторону, т.к. указанный выше плагин, по личным наблюдения, использует именно таку формулу
print "$result";// ну и выводим результат
?>
*

Zuev

  • Захожу иногда
  • 211
  • 15 / 1
  • В дальнем плавании
Сам завел тему, сам пообщался, сам ответил, Клево.

Может кому то пригодится
*

Zuev

  • Захожу иногда
  • 211
  • 15 / 1
  • В дальнем плавании
уже обнаружена  ошибка "деление на ноль", требуется доп проверка аргумента, чуть позже вылажу
*

Zuev

  • Захожу иногда
  • 211
  • 15 / 1
  • В дальнем плавании
 <?php
$db = & JFactory::getDBO();
$article_id = 49; //id статьи он у меня заранее ивестен поэтому ставлю его сразу
$query = 'SELECT *' . ' FROM #__content_rating' . ' WHERE content_id = ' . (int) $article_id;//делаем выборку в базе по id статье
$db->setQuery($query);
$rating = $db->loadObject(); //получаем все поля данных (content_id, rating_sum, rating_count и lastip) из таблицы jos_content_rating

$sgolosov = $rating->rating_count;//берем из $rating параметр rating_count (общее количество проголосовавших)
if ($sgolosov > 0) {
$summa_balov = $rating->rating_sum;//берем из $rating параметр rating_sum (общее количество баллов)
$result = ceil($summa_balov / $sgolosov); //дели баллы на голоса и округляем в большую сторону, т.к. указанный выше плагин, по личным наблюдения, использует именно таку формулу
print "$result";// ну и выводим результат
} else {
print "0";
}
?>
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
замечательно, если ты это все добро оформишь еще в виде плагина - будет еще чудесатее :)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Поиск статьи по url сайта в админке Joomla 1.5

Автор Tema

Ответов: 5
Просмотров: 2035
Последний ответ 14.08.2020, 07:16:44
от rsn
модуль Newsflash: как вывести дату?

Автор joomloid

Ответов: 5
Просмотров: 3588
Последний ответ 03.04.2019, 12:25:27
от pH43
Как вывести все категории всех разделов на одной странице?

Автор genius

Ответов: 4
Просмотров: 2227
Последний ответ 22.01.2019, 08:38:30
от genius
Как вывести список новых статьи?

Автор maxo127

Ответов: 4
Просмотров: 2378
Последний ответ 16.06.2018, 02:44:50
от maxo127
После редактирования статьи появляются символы Â

Автор Ra_insider

Ответов: 7
Просмотров: 4899
Последний ответ 30.01.2018, 20:33:39
от Petrovich