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

Benediction

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Мое приветствие форумчанам !

Для Комментариев установлен компонент Joomla Comments
В мобильной версии (адаптивный шаблон Joomla 1.5) на смартфоне сами комментарии отображаются нормально, не срезаются. А форма заполнения срезается.

Я прописал в CSS Mobile шаблона (а также в CSS компонента комментариев):

input, textarea { max-width: 100% }

@viewport {
width: device-width; }

Но это 'лекарство' не помогло.

Может быть есть другие вариант решения проблемы?
*

kik84

  • Завсегдатай
  • 1350
  • 64 / 4
Так, наверное, выше, весь div имеет фиксированную ширину в px.
*

Benediction

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Так, наверное, выше, весь div имеет фиксированную ширину в px.

В CSS не нашел жесткой фиксации в px

« Последнее редактирование: 04.02.2016, 18:12:18 от Benediction »
*

Benediction

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
не делайте так.
уберите ваш код и дайте ссылку на сайт




« Последнее редактирование: 05.02.2016, 15:48:59 от Benediction »
*

Shustry

  • Moderator
  • 6434
  • 745 / 3
Вот же у вас фиксится

Код: css
#maininner {
    width: 740px;
}
#sidebar-a {
    width: 260px;
}
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
а каким местом он вообще адаптивен?
в Chrome что-то еще пытается перестроиться, а в лисе так вообще как гвоздями все прибито.
разве что в php определяет тип устройства и чего-то под это дело грузит.
но в целом надо шаблон переделывать, если вас адаптивность волнует
*

Benediction

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
а каким местом он вообще адаптивен?
в Chrome что-то еще пытается перестроиться, а в лисе так вообще как гвоздями все прибито.
разве что в php определяет тип устройства и чего-то под это дело грузит.
но в целом надо шаблон переделывать, если вас адаптивность волнует

Странно.. в Firefox на моем смартфоне сразу адаптивн. версию загружает.. и в других браузерах

когда настраивал шаблон, проверял https://www.google.com/webmasters/tools/mobile-friendly/   пишет, всё норм.

Да и кол-во мобильных юзеров до 40 проц увеличилось


*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
ну значит у вас определяется по типу устройства на сервере и под это дело грузит свою разметку.
просто в таком варианте нам трудно вам помочь - мы со стационарных компов работаем и на них никакой адаптивности нет.

по хорошему, вам бы найти место, где определяется, каким шаблоном будет выводиться сайт и принудительно выставить ему мобильный вид. тогда можно будет лазать файербагом и смотреть, что именно распирает вашу форму.
например, это может быть нижний текст itemsmall или, наоборот, заголовок таблицы.
*

Benediction

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Вот же у вас фиксится

Код: css
#maininner {
    width: 740px;
}
#sidebar-a {
    width: 260px;
}


Да, сейчас посмотрел - спасибо за подсказку! Это в <style>body  ..  А в каком CSS может быть прописан это стиль ?
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
вы выборочно читаете?
я же написал русским по белому, что то, что мы видим у себя на компьютере и то, что у вас в мобильном устройстве - это два разных шаблона.
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
вам надо с мобильного устройства посмотреть, какие стили грузятся и туда попробовать прописать max-width для инпутов и самой таблицы
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Некорректное отображение сайта на смартфоне

Автор Bazilio_69

Ответов: 0
Просмотров: 1149
Последний ответ 04.09.2024, 20:36:06
от Bazilio_69
Изменить заголовок в шапке сайта

Автор kunsaid

Ответов: 0
Просмотров: 2610
Последний ответ 03.12.2022, 18:34:32
от kunsaid
Как убрать боковые отступы в мобильной версии шаблона?

Автор Евгений1980

Ответов: 2
Просмотров: 1612
Последний ответ 18.01.2021, 18:24:53
от arma
Ссылки в меню в мобильной версии

Автор Андрей Нестеров

Ответов: 1
Просмотров: 1985
Последний ответ 11.12.2019, 10:47:20
от sivers
Адаптивное меню для сайта на CSS

Автор YuliaOks

Ответов: 1
Просмотров: 1321
Последний ответ 02.06.2019, 19:31:23
от Taatshi