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

addrss

  • Осваиваюсь на форуме
  • 34
  • 0 / 0
Добрый день. Помогите разобраться.

Для работы фиксированного меню IceMegaMenu на JQuery написаны два CSS класса меню  - .default и .fixed.

Для скроллинга меню в мобильной версии сайта в стиле .fixed установлены значения overflow: auto; и max-height: 50%;
В мобильной версии сайта развернутое меню занимает максимум 50% страницы и прокручиваются все не влазящие пункты меню, что дает возможность прокручивать и меню и контент. Но в обычной версии сайта фиксированное меню полностью не разворачивается и появляется полоса прокрутки.

Если отключить overflow: auto; и max-height: 50%;, то в мобильной версии сайта на маленmких экранах меню раскрывается  не полностью: по высоте не влазят все пункты меню и нет возможно скроллинка.
 
Все примеры на видео: http://www.yapfiles.ru/show/1174253/02a4520dd929a52cacdfa96b0710c138.mp4.html

Как убрать полосы прокрутки в обычной версии сайта с помощью CSS или Javascrip и эффектов JQuery?
Или как назначить разные классы меню для обычной и мобильной версий сайта?

Классы меню:

Код
/* IceMegaMenu */
#mainmenu {
/*  position: relative;*/
  background-color: #3d3d3d;
  background: -moz-linear-gradient(top, #484848, #2e2e2e);
  background: -webkit-gradient(linear, 0 0, 0 100%, from(#484848), to(#2e2e2e));
  background: -webkit-linear-gradient(top, #484848, #2e2e2e);
  background: -o-linear-gradient(top, #484848, #2e2e2e);
  background: linear-gradient(to bottom, #484848, #2e2e2e);
  background-repeat: repeat-x;
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff484848', endColorstr='#ff2e2e2e', GradientType=0);
  clear: both;
  margin: 0 0 30px;
  border-radius: 7px 8px 8px 7px;
  /* Search */

}

.default {
position: relative;
top: 0;
  left: 0;
  height: 55px;
  background: url(../images/mainmenu.png) no-repeat;
  width: 100%;
  border-radius: 7px;
}
.fixed {
position: fixed;
overflow: auto;
z-index:15000;
width:100%;
top:0;
right:0;
left:0;
max-height:50%;
}

#mainmenu:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 55px;
  background: url(../images/mainmenu.png) no-repeat;
  width: 100%;
  border-radius: 7px;
}



Скрипт фиксированного меню на JQuery:
Код
jQuery(document).ready(function(){

 

        var jQuerymenu = jQuery("#mainmenu");

 

        jQuery(window).scroll(function(){

            if ( jQuery(this).scrollTop() > 100 && jQuerymenu.hasClass("default") ){

                jQuerymenu.removeClass("default").addClass("fixed");

            } else if(jQuery(this).scrollTop() <= 100 && jQuerymenu.hasClass("fixed")) {

                jQuerymenu.removeClass("fixed").addClass("default");

            }

        });//scroll

    });
« Последнее редактирование: 07.06.2015, 16:37:52 от addrss »
*

addrss

  • Осваиваюсь на форуме
  • 34
  • 0 / 0
Нашел решение через медиа запросы.
в template.css после стиля .fixed дописал:
Код
@media screen and (max-height: 600px) {
     .fixed {
     overflow: auto!important;
     max-height:50%!important;
 }
   }
*

addrss

  • Осваиваюсь на форуме
  • 34
  • 0 / 0
Добавлю небольшую поправку, если кто-то столкнется с такой же проблемой: в коде лучше прописать only handheld, это значит что стиль будет применяться только для мобильных устройств. Иначе прокрутка останется, если окно браузера на десктопе уменьшить до высоты 600px

Код
@media only handheld and (max-height: 600px) {
     .fixed {
overflow: auto!important;
max-height: 50%!important;
 }
}
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

В новом шаблоне не адаптируется изображение

Автор Ebelous

Ответов: 4
Просмотров: 2583
Последний ответ 13.02.2024, 17:01:12
от Vastriet
Как уменьшить отступ между Title и Components в шаблоне Helix3

Автор artem_wrong

Ответов: 21
Просмотров: 5891
Последний ответ 17.06.2022, 22:42:47
от Scaltro
Кликабельность псевдоэлемента в пункте меню

Автор vasilii.pupkov

Ответов: 4
Просмотров: 3224
Последний ответ 29.12.2021, 23:15:38
от v42bis
Выпадающее меню

Автор DrShepard

Ответов: 10
Просмотров: 2896
Последний ответ 20.10.2021, 12:36:16
от DrShepard
Как убрать боковые отступы в мобильной версии шаблона?

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

Ответов: 2
Просмотров: 1610
Последний ответ 18.01.2021, 18:24:53
от arma