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

Ragivort

  • Завсегдатай
  • 1154
  • 58 / 2
  • Такая Life
Всем привет.
Возникла задача сделать разворачивание фото у товара и видео не с помощью lightbox, а с помощью magnific popup.
Плюс, была задача сделать так, чтобы превью разворачивались сразу при клике, как и видео во всплывающем окне.
Есть платные решения, но там много лишнего.
С видео было еще вот что - код вставлялся в товар, как HTML, а я сделал так, чтобы вставлять как ссылку на видео.
Итак, решение.
Подключаем magnific.js  и .css файлы.
http://dimsemenov.com/plugins/magnific-popup/
Код
<script src="<?php echo $this->baseurl ?>/templates/<?php echo $this->template ?>/js/magnific.js"></script>
<link href="<?php echo $this->baseurl ?>/templates/<?php echo $this->template ?>/css/magnific.css" rel="stylesheet" type="text/css">
В index.php шаблона, или иным удобным способом.

Далее идем в шаблон product_default.php отображение страницы товара в JoomShopping.

Я убрал большое изображение товара, оставив только превью, которые разворачиваются в галерею.
Меняем отображение превью на
Код
			<div class="popup-gallery">	
                               
                <span id='list_product_image_thumb'>
                    <?php if ( (count($this->images)>1) || (count($this->videos) && count($this->images)) ) {?>
                        <?php foreach($this->images as $k=>$image){?>
<a href="<?php print $this->image_product_path?>/<?php print $image->image_full;?>"  title="<?php print htmlspecialchars($image->_title)?>">
                            <img class="jshop_img_thumb" src="<?php print $this->image_product_path?>/<?php print $image->image_thumb?>" alt="<?php print htmlspecialchars($image->_title)?>" title="<?php print htmlspecialchars($image->_title)?>" />
                    </a>
<?php }?>
                    <?php }?>
                </span>
</div>
То есть, просто в div с классом popup-gallery вставляются наши превью. Получается красивая центрированная галерея.
Пример: http://prntscr.com/ihpy4w
http://prntscr.com/ihpyc0

Для того, чтобы галерея заработала, в самый низ файла добавляем скрипт:
Код
$(document).ready(function() {
$('.popup-gallery').magnificPopup({
delegate: 'a',
type: 'image',
tLoading: 'Loading image #%curr%...',
mainClass: 'mfp-img-mobile',
gallery: {
enabled: true,
navigateByImgClick: true,
preload: [0,1] // Will preload 0 - before current, and 1 after the current image
},
image: {
tError: '<a href="%url%">The image #%curr%</a> could not be loaded.',
}
});
});

Доп опции можно посмотреть на сайте плагина

С видео интересней.
В товаре, во вкладке видео выбираем вставить код. И вставляем просто ссылку на видео в Youtube.

Далее, в место, где хотите вставить видео
Код
                  <?php if (count($this->videos)){?>

                    <?php foreach($this->videos as $k=>$video){?>
                        <?php if ($video->video_code) { ?>
    <a class="popup-youtube" href="<?php echo $video->video_code?>" id="video_<?php print $k?>"><img class="jshop_img_thumb" src="<?php print $this->video_image_preview_path."/"; if ($video->video_preview) print $video->video_preview; else print 'video.gif'?>" alt="video" />
</a>
                        <?php } else { ?>
                            <a href="<?php print $this->video_product_path?>/<?php print $video->video_name?>" id="video_<?php print $k?>" onclick="showVideo(this.id, '<?php print $this->config->video_product_width;?>', '<?php print $this->config->video_product_height;?>'); return false;"><img class="jshop_video_thumb" src="<?php print $this->video_image_preview_path."/"; if ($video->video_preview) print $video->video_preview; else print 'video.gif'?>" alt="video" /></a>
                        <?php } ?>
                    <?php } ?>
                <?php }?>

А в низ файла скрипт

Код
$(document).ready(function() {
$('.popup-youtube, .popup-vimeo, .popup-gmaps').magnificPopup({
disableOn: 700,
type: 'iframe',
mainClass: 'mfp-fade',
removalDelay: 160,
preloader: false,

fixedContentPos: false
});
});

Важный момент - превью у видео не будет. Тут я делаю просто картинку - заглушку. При нажатии на картинку всплывает окно с плеером.
Пример: http://prntscr.com/ihq099

Вот и все.
Если уже было, извините, можете удалить, я не нашел.
Дозволь мне свершить то добро, которое я способен свершить, теперь, ибо я могу более не вернуться сюда.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться