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

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Когда контента на странице мало как пример - страница восстановления пароля), то футер поднимается достаточно высоко над нижней границей окна браузера.
Как сделать так, чтобы при прокручивании страницы, где контента много, футер уезжал вниз, оставаясь под контентом, но при этом никогда не поднимался над нижней границей окна браузера, если контента на странице мало, т.е. всегда bottom <= 0?
*

aspidy

  • Завсегдатай
  • 1008
  • 55 / 1
  • Миграция joomla 1.0-1.5-2.5
Re: Закрепление футера при прокрутке
« Ответ #1 : 29.07.2014, 07:30:15 »
Попробуйте
   
   margin:0 auto;
   padding: 0px;
   clear:both;
   margin-bottom:0px;

В контенте тоже должно добавляться position:relative;   
Мелкий ремонт. skype poisk-plus
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Закрепление футера при прокрутке
« Ответ #2 : 29.07.2014, 07:46:26 »
Не то.
Пример:
Высота окна браузера (примерно, т.к. она переменна - моники у всех разные) 1000px
Шапка (высота) - 200px, контент - 300px, подвал - 200px, под подвалом белая полоса в 300px.
Нужно, чтобы подвал приклеился к низу, а белая полоса была между подвалом и контентом.

При этом, если контент по высоте 1500px и соот-но уползает вниз за границу окна браузера, подвал должен быть приклеен к контенту, т.е  находится под ним (как обычно, в общем).
Чувствую, тут однис ксс не обойтись, а скрипт нарисовать не догоню как.
*

sergoguga

  • Давно я тут
  • 896
  • 70 / 8
  • www.mpbox.ru
>>> Верстка 100 евро - ждешь новый курс? Пиши!
>>> Создание моб. приложений по ГОСТу)))! Личка работает!
>>> Микроразметка по стандартам - цены адекват! Пиши, не боись!
>>> Личный кабинет на ZOO - уже сделан! Пиши в личку, не стесняйся!
*

aspidy

  • Завсегдатай
  • 1008
  • 55 / 1
  • Миграция joomla 1.0-1.5-2.5
Re: Закрепление футера при прокрутке
« Ответ #4 : 29.07.2014, 09:38:35 »
Цитировать
Чувствую, тут однис ксс не обойтись, а скрипт нарисовать не догоню как.
Для менюшки звучит так:
 <script type="text/javascript">
          $(function() {
                $('#main-menu li a').bind('click',function(event){
                    var $anchor = $(this);
                   
                    $('html, body').stop().animate({
                        scrollTop: $($anchor.attr('href')).offset().top
                    }, 1500,'easeInOutExpo');

                    event.preventDefault();
                });
            });
         
           $(document).ready(function(){
          $("a[rel^='prettyPhoto']").prettyPhoto({social_tools:false, deeplinking: false});
           });

        </script>
Для футера я думаю, будет так же (лишнее за комментируйте и поменяйте на футер)
Мелкий ремонт. skype poisk-plus
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Закрепление футера при прокрутке
« Ответ #5 : 29.07.2014, 20:24:47 »
млять, нажми на меня! пжлст!
Можно было и без экспрессии. Это решение (русскоязычное) не помогло, помог англоязычный вариант http://getbootstrap.com/examples/sticky-footer/ (отличается от русского версткой), конкретное решение:
Код: css
html {position:relative;min-height:100%;}
footer {position:absolute;bottom:0;width:100%;}
и все, безо всяких скриптов, всего-то...

Решено.
« Последнее редактирование: 29.07.2014, 20:28:25 от AlekVolsk »
*

sergoguga

  • Давно я тут
  • 896
  • 70 / 8
  • www.mpbox.ru
Re: Закрепление футера при прокрутке
« Ответ #6 : 29.07.2014, 21:50:29 »
Можно было и без экспрессии. Это решение (русскоязычное) не помогло, помог англоязычный вариант http://getbootstrap.com/examples/sticky-footer/ (отличается от русского версткой), конкретное решение:
Код: css
html {position:relative;min-height:100%;}
footer {position:absolute;bottom:0;width:100%;}
и все, безо всяких скриптов, всего-то...

Решено.
думаю вы немного не правы дружище, ну да ладно, как-нибудь увидите ошибку)))) имхо, ваш код не везде срабатывает, ибо не самодостаточен))))
и в русской версия и в англ версиях одно и то же, покажите какие вы РАЗЛИЧИЯ нашли? в названиях классов?))))
а то, что тут можно обойтись без скриптов - дыг Google трещит))) тут не можно, а нужно без скриптов....))) их и так в наше смутное время на каждом шагу и а за каждым углом немеряно! к бабке хохляцкой не ходи!
>>> Верстка 100 евро - ждешь новый курс? Пиши!
>>> Создание моб. приложений по ГОСТу)))! Личка работает!
>>> Микроразметка по стандартам - цены адекват! Пиши, не боись!
>>> Личный кабинет на ZOO - уже сделан! Пиши в личку, не стесняйся!
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Закрепление футера при прокрутке
« Ответ #7 : 29.07.2014, 23:37:19 »
Для основного контейнера сразу над футером:
min-height:100%;
height:auto !important;
margin-bottom: указать высоту футера
margin-top: указать высоту хедера, если он не внутри контейнера или не зфиксирован
« Последнее редактирование: 29.07.2014, 23:55:06 от AlekVolsk »
*

fbr

  • Завсегдатай
  • 1672
  • 206 / 7
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться