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

kolhoz

  • Захожу иногда
  • 199
  • 0 / 0
В БД есть таблица k2_items, она содержит практически всю необходимую мне информацию, кроме изображения материала. Подскажите пожалуйста как в запросе можно получить ссылки на изображения материалов? image_caption и image_credits поля у меня пустые.
« Последнее редактирование: 06.12.2017, 13:56:57 от kolhoz »
*

Septdir

  • Живу я здесь
  • 3370
  • 168 / 4
Имя файла картики это
Код
md5('Image' . $item->id)

Код
media/k2/items/src/' . md5('Image' . $item->id). '.jpg'
Не можете справиться с задачей сами пишите, решу ее за вас, не бесплатно*.
*Интересная задача, Деньги или Бартер. Натурой не беру!
CodersRank | Контакты | Мой GitHub | Workshop
*

kolhoz

  • Захожу иногда
  • 199
  • 0 / 0
Имя файла картики это
Код
md5('Image' . $item->id)

Код
media/k2/items/src/' . md5('Image' . $item->id). '.jpg'

Меня интересовало как написать запрос, который помимо полей id, cat_id, title и т.д. в таблице k2_items выбирал бы еще и ссылку на картинку в колонке image
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
Берем файл itemlist.php (JPATH_ROOT/components/com_k2/models)
опускаемся до 40 строки и видим
Код: sql
$query = "SELECT i.*,";
судя по строке 54 буква i определяет таблицу #__k2_items
Код: sql
$query .= " FROM #__k2_items as i RIGHT JOIN #__k2_categories AS c ON c.id = i.catid";
Тебе же она нужна...
Ну так вот если i.*, значит что вся информация о материале будет выводится.
Так же само и в остальных файлах, где используется эта таблица...

Вывести можно так же как и все остальное
Код: php
<?php echo $item->image_caption; ?>
<?php echo $item->image_credits; ?>
Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

kolhoz

  • Захожу иногда
  • 199
  • 0 / 0
Берем файл itemlist.php (JPATH_ROOT/components/com_k2/models)
опускаемся до 40 строки и видим
Код: sql
$query = "SELECT i.*,";
судя по строке 54 буква i определяет таблицу #__k2_items
Код: sql
$query .= " FROM #__k2_items as i RIGHT JOIN #__k2_categories AS c ON c.id = i.catid";
Тебе же она нужна...
Ну так вот если i.*, значит что вся информация о материале будет выводится.
Так же само и в остальных файлах, где используется эта таблица...

Вывести можно так же как и все остальное
Код: php
<?php echo $item->image_caption; ?>
<?php echo $item->image_credits; ?>


Все равно непонятно как запросом получить ссылку на изображение. Данные о самом материале я спокойно могу получить, но там нет ссылки на картинку материала.

Код
SELECT c068t_k2_items.*, c068t_k2_categories.name as catname from c068t_k2_items join c068t_k2_categories on c068t_k2_items.catid = c068t_k2_categories.id where c068t_k2_items.catid in (12)
  вот так я вытаскиваю инфо о материалах из категории 12. Как в этот запрос добавить колонку изображения материала?
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
Все равно непонятно как запросом получить ссылку на изображение. Данные о самом материале я спокойно могу получить, но там нет ссылки на картинку материала.

Код
SELECT c068t_k2_items.*, c068t_k2_categories.name as catname from c068t_k2_items join c068t_k2_categories on c068t_k2_items.catid = c068t_k2_categories.id where c068t_k2_items.catid in (12)
  вот так я вытаскиваю инфо о материалах из категории 12. Как в этот запрос добавить колонку изображения материала?

Тяжелый случай!
У тебя из таблицы c068t_k2_items.* выводится вся информация о материале (потому что стоит звездочка, а если бы не стояла то пришлось бы перечислять все столбцы которые надо).
Покажи как выводишь catname?
Что находится в столбцах image_caption и image_credits
Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

kolhoz

  • Захожу иногда
  • 199
  • 0 / 0
По-моему ты не понял меня. Смотри.. В БД в колонках image_caption и image_credits у меня ничего нет ни для одного материала. т.е. эти колонки пустые для всех записей в БД. Поэтому у меня и возник вопрос как получить ссылку на изображение материала. Может ссылки на картинки хранятся в другом месте или вообще не хранятся в явном виде в БД (в виде ссылок)

Вот таким запросом я получаю все новости. В полученной выборке поля image_caption и image_credits пустые

Код
SELECT c068t_k2_items.*, c068t_k2_categories.name as catname from c068t_k2_items join c068t_k2_categories on c068t_k2_items.catid = c068t_k2_categories.id where c068t_k2_items.catid in (76)
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
В столбце image_credits хранится только имя файла!
Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

Septdir

  • Живу я здесь
  • 3370
  • 168 / 4
В столбце image_credits хранится только имя файла!
Ничего там не храниться не путайте людей.
. Может ссылки на картинки хранятся в другом месте или вообще не хранятся в явном виде в БД (в виде ссылок)
Видать вы меня не допонили. ссылки на картинки материала k2 НЕ хранятся в базе.

Лежать ВСЕ картинки в папках
media/k2/items/src/ - оригиналы
media/k2/items/cache/ - "оптимизированные"
Имя файла получается следующим образом.
Код
md5('Image' . $item->id)
Где item->id = id материала.

Поэтому самым разумным решением, будет просто добавлять картинку не посредственно в цикле
Не можете справиться с задачей сами пишите, решу ее за вас, не бесплатно*.
*Интересная задача, Деньги или Бартер. Натурой не беру!
CodersRank | Контакты | Мой GitHub | Workshop
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Автоматическая дата снятия с публикации материала

Автор kozhenevsky

Ответов: 10
Просмотров: 4309
Последний ответ 17.11.2023, 08:08:49
от Vastriet
В Joomla! 3.9.1 в к2 не меняется порядок расположения материала

Автор sergspb

Ответов: 0
Просмотров: 826
Последний ответ 12.06.2021, 15:20:52
от sergspb
Ошибка ПРИ создании материала В К2 - РЕШЕНО

Автор korchaga

Ответов: 1
Просмотров: 927
Последний ответ 28.12.2020, 03:21:46
от korchaga
Ошибка дополнительных полей в конце материала

Автор Vekach

Ответов: 4
Просмотров: 1132
Последний ответ 22.09.2020, 17:45:22
от Vekach
[Решено] Получить alias материала в плагине, как?

Автор x1

Ответов: 10
Просмотров: 1212
Последний ответ 23.07.2020, 11:45:07
от x1