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

antipod

  • Захожу иногда
  • 66
  • 2 / 0
    Тут  https://www.zegeberg.ru/sobstven-sate/optimisaziya-joomla/adaptatsiya-tablits-pod-mobilnye-ustroystva  эсть инструкция, как сделать отображении таблицы в колонку, если она отображается на мобильных.
    Но я не смог ею воспользоваться. Испробовал разные варианты, но в Opera, в отладчике, моя таблица все равно отображается таблицей.
   
   в одну из CSSсок, подключенной к сайту, внизу вставил.

@media only screen and (max-width: 320px),(min-device-width: 320px) and (max-device-width: 600px) /* Force table to not be like tables anymore */
table.mceItemTable, table.mceItemTable thead, table.mceItemTable tbody, table.mceItemTable th, table.mceItemTable td, table.mceItemTable tr {display: block; }
   
   а вот что дальше?  У меня в CSS-ках есть класс <table..>, в нем уже есть параметры, я так понимаю в него нужно внести правки, добавление просто  mceItemTable ничего не поменяло.
« Последнее редактирование: 30.06.2024, 17:53:58 от antipod »
*

web1

  • Захожу иногда
  • 351
  • 20 / 1
Здраствуйте, у меня ваш сайт не грузится, VPN не хочу включать, а вот что я нашел в YouTube
*

web1

  • Захожу иногда
  • 351
  • 20 / 1
Также рекомендую для общего развития посмотреть это.

Самый легкий вариант добавить горизонтальный скролинг таблице, подробнее в ссылке выше.
« Последнее редактирование: 30.06.2024, 20:30:04 от web1 »
*

antipod

  • Захожу иногда
  • 66
  • 2 / 0
Я читал эту статью, вчера и многие другие. Я уже по моему все варианты попробовал.
Я сохранял страницу как файл, правил ее. - никакого результата видимого.
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Мой опыт адаптации многоколоночной верстки для мобильных устройств показал, что лучше использовать верстку от Bootstrap4.
Например, для таблицы использовать класс "table-responsive".
Этот класс включает на мобильных устройствах горизонтальную прокрутку.
Если же надо верстку из нескольких колонок преобразовать в 1 или 2 колонки, то делать верстку, не используя таблицы (table), а ипользовать систему сеток bootstrap https://bootstrap-4.ru/docs/4.0/layout/grid/

*

web1

  • Захожу иногда
  • 351
  • 20 / 1
Здраствуйте, то есть если подключен bootstrap в шаблоне то только прописать class к таблице <table class="table-responsive"> и будет горизонтальный скрол в таблице?
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Здраствуйте, то есть если подключен bootstrap в шаблоне то только прописать class к таблице <table class="table-responsive"> и будет горизонтальный скрол в таблице?
Я сделал div, в который заключил таблицу.
Код
<div class="table-responsive">
<table ...
</div>
Почитайте документацию https://bootstrap-4.ru/docs/4.0/content/tables/
Там много интересного про стилизацию таблиц.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Таблица cодержит некорректный тип или атрибуты для столбца

Автор salesekspert

Ответов: 15
Просмотров: 1390
Последний ответ 03.06.2025, 16:39:46
от azm1n
Как сделать адаптивный слайд на сотовом у smart slider 3?

Автор antipod

Ответов: 2
Просмотров: 801
Последний ответ 17.07.2024, 09:03:48
от Vastriet
Баг в отображении материалов Joomla 4 и Joomla 5

Автор Ebelous

Ответов: 1
Просмотров: 789
Последний ответ 07.03.2024, 23:02:33
от Ebelous
Адаптивная таблица в материале

Автор phvsfpgs

Ответов: 3
Просмотров: 1031
Последний ответ 18.09.2023, 00:58:25
от phvsfpgs
Таблица finder_links

Автор slalexpost

Ответов: 1
Просмотров: 1042
Последний ответ 22.05.2023, 11:17:15
от b2z