Новости Joomla

Новый способ добавления и рендера полей в Joomla Form - метод renderControlFields() (Joomla 5.3+)

Новый способ добавления и рендера полей в Joomla Form - метод renderControlFields() (Joomla 5.3+)

Новый способ добавления и рендера полей в Joomla Form - метод renderControlFields() (Joomla 5.3+). При отображении форм компонента в админке раньше разработчикам нужно было описывать скрытые поля в лейаутах. И выглядело это так:

<?php     // Это файл в /layouts/components/com_component/your_layout.php?><input type="hidden" name="task" value=""><input type="hidden" name="return" value="<?php echo $input->getBase64('return'); ?>"><input type="hidden" name="forcedLanguage" value="<?php echo $input->get('forcedLanguage', '', 'cmd'); ?>"><?php echo HTMLHelper::_('form.token'); ?>
Начиная с Joomla 5.3 добавлен новый способ добавления таких полей (их называют control fields) - программно. И теперь это можно сделать просто в Controller / View.
// В Controller/View добавляем поля$this->form  ->addControlField('task', '')  ->addControlField('return', $input->getBase64('return', ''))  ->addControlField('forcedLanguage', $forcedLanguage);
А в layout'е просто используем метод
renderControlFields()
// В layout формыecho $this->form->renderControlFields();
Многие компоненты ядра уже используют этот подход. Соответствующий PR был принят в Joomla 5.3 осенью 2024г.Смотреть
Pull Request@joomlafeed#joomla #разработка #php

JoomGallery 4.1.0 - компонент галереи изображений для Joomla

JoomGallery 4.1.0 - компонент галереи изображений для Joomla

Новая итерация компонента продолжает развиваться, ведь с v.4.x компонент был переписан практически с нуля.

v.4.1.0. Что нового?

Редактирование метаданных изображений. Теперь метаданные можно не только читать, но и напрямую редактировать и записывать обратно в изображение JPG. Поддерживаются данные EXIF ​​и IPTC.

Полная совместимость с Joomla! 4.x, 5.x и 6.x. Компонент почистили от устаревших методов в коде.

Заметно ускорили загрузку больших галерей. Списки в админке, особенно для очень больших галерей ( >30 000 изображений), теперь загружаются значительно быстрее.

Несколько сеток lightGallery на одной странице. Будь то плагины контента или модули изображений: теперь вы можете отображать несколько галерей или категорий на одной странице без каких-либо ограничений.

Множество мелких исправлений ошибок и оптимизаций.

Сайт проекта

GitHub расширения

Скачать

0 Пользователей и 1 Гость просматривают эту тему.
  • 1 Ответов
  • 1490 Просмотров
*

a159cm

  • Захожу иногда
  • 71
  • 0 / 0
Есть такая хрень.. Как ее исправить?
https://developers.google.com/speed/pagespeed/insights/?url=https%3A%2F%2Fprosalsk.ru%2F&tab=desktop

ругается на эту ссылку https://yastatic.net/s3/front-maps-static/maps-front-jsapi-v2-1/2.1.78-11/build/release/full-ffb813a29f30feadb63b5654242d042b7b6a91aa.js

выводится вроде бы так
Код
<script async>
function getYaMap(){
    var myMap = new ymaps.Map('map', {
            center: [<?php echo $center[0] ?>, <?php echo $center[1] ?>],
            zoom: <?php echo $zoom_map ?>,
controls: ["zoomControl"]
        }, {
            searchControlProvider: 'yandex#search'
        }),


        /**
         * Создадим кластеризатр, вызвав функцию-конструктор.
         * Список всех опий доступен в документации.
         * @see https://api.yandex.ru/maps/doc/jsapi/2.1/ref/reference/Clusterer.xml#constructor-summary
         */
            clusterer = new ymaps.Clusterer({
            /**
             * Чеез кластеризатор можно указать тоько стили кластеов,
             * стил для меток нужно азначать каждой етке отдельно.
             * @see https://api.yandex.ru/maps/doc/jsapi/2.1/ref/reference/option.presetStorage.xml
             */
            preset: 'islands#invertedRedClusterIcons',
            /**
             * Ставим true, если хотим кластеризовать только точки с одинаковыми координатами.
             */
            groupByCoordinates: false,
            /**
             * Опции кластеров указывем в кластеризатре с префиксом "cluster".
             * @see https://api.yandex.ru/maps/doc/jsapi/2.1/ref/reference/ClusterPlacemark.xml
             */
            clusterDisableClickZoom: true,
            clusterHideIconOnBalloonOpen: false,
            geoObjectHideIconOnBalloonOpen: false
        }),
        /**
         * Функция озвращает объект, содержащий данне метки.
         * Поле данных clusterCaption будет отображено в списке геообъетов в балуне кластера.
         * Поле balloonContentBody - источник данных для конента балуна.
         * Оба поля поддерживают HTML-разметку.
         * Список плей данных, которые используют стандартные макеты содержимого иконк метки
         * и балуна геообъектов, можно посмотреть в документации.
         * @see https://api.yandex.ru/maps/doc/jsapi/2.1/ref/reference/GeoObject.xml
         
            getPointData = function (index) {
            return {
                balloonContentHeader: '!',
                balloonContentBody: '',
                balloonContentFooter: '',
                clusterCaption: ''
            };
        },
        /**
         * Фнкция возвращает объект, содержащй опции метки.
         * Все опции, которые поддерживаю геообъекты, можно посмотреть в доументации.
         * @see https://api.yandex.ru/maps/doc/jsapi/2.1/ref/reference/GeoObject.xml
         */
getPointOptions = [
<?php foreach ($list as $item) { ?>
{
//preset: "islands#redAttentionCircleIcon",
            // Опции.
            // Необходимо указать данный тип макта.
            iconLayout: 'default#image',
            // Своё изображение иконки метки.
<?php if($item->parent_id == 11) { $ic = 'auto.png'; }
if($item->parent_id == 20) { $ic = 'bank.png'; }
if($item->parent_id == 24) { $ic = 'flag.png'; }
if($item->parent_id == 35) { $ic = 'kafe.png'; }
if($item->parent_id == 37) { $ic = 'deti.png'; }
if($item->parent_id == 53) { $ic = 'shop.png'; }
if($item->parent_id == 79) { $ic = 'razvlecheniya.png'; }
if($item->parent_id == 84) { $ic = 'medical.png'; }
if($item->parent_id == 92) { $ic = 'obrazovanie.png'; }
if($item->parent_id == 97) { $ic = 'home.png'; }
if($item->parent_id == 111) { $ic = 'krasota.png'; }
if($item->parent_id == 116) { $ic = 'sport.png'; }
if($item->parent_id == 128) { $ic = 'eda.png'; }
if($item->parent_id == 137) { $ic = 'business.png'; }
if($item->parent_id == 147) { $ic = 'turizm.png'; }
if($item->parent_id == 2010) { $ic = 'uslugi.png'; }
if($item->parent_id == 2019) { $ic = 'proizvodstvo.png'; }
if($item->parent_id == 2023) { $ic = 'selhoz.png'; }
?>
            iconImageHref: "images/icons/map/<?php echo $ic ?>",
            // Размеры метки.
            iconImageSize: [32, 32],
            // Смещение левого верхнего угла иконки относительно
            // её "нжки" (точки привяки).
            iconImageOffset: [-16, -16]
},
<?php } ?>
],
   
        points = [
<?php foreach ($list as $key => $item) {
$link = JRoute::_(ContentHelperRoute::getArticleRoute($item->slug, $item->catid, $item->language));
$img = json_decode($item->images)->image_intro;

JLoader::register('FieldsHelper', JPATH_ADMINISTRATOR . '/components/com_fields/helpers/fields.php');
$jcfields = FieldsHelper::getFields('com_content.article', $item, true);
foreach($jcfields as $fields) {
$f[$fields->id] = $fields;
}
$t = '['.$f[109]->value.'],';

?>
<?php echo $t ?>
<?php } ?>
        ],
balloonContentHeader = [
<?php foreach ($list as $key => $item) {
$link = JRoute::_(ContentHelperRoute::getArticleRoute($item->slug, $item->catid, $item->language));
$img = json_decode($item->images)->image_intro;

JLoader::register('FieldsHelper', JPATH_ADMINISTRATOR . '/components/com_fields/helpers/fields.php');
$jcfields = FieldsHelper::getFields('com_content.article', $item, true);
foreach($jcfields as $fields) {
$f[$fields->id] = $fields;
}
$b = '{
balloonContentHeader: `<div class="map_item_img"><img src="'.$img.'"/></div><div class="map_item_info"><h3><a href="'.$link.'">'.$item->title.'</a></h3><div>'.$f[1]->value.'</div></div>`,
},';
?>
<?php echo $b ?>
<?php } ?>
]
        geoObjects = [];

    /**
     * Данные передаются вторым параметром в коструктор метки, опции - третьим.
     * @see https://api.yandex.ru/maps/doc/jsapi/2.1/ref/reference/Placemark.xml#constructor-summary
     */
    for(var i = 0, len = points.length; i < len; i++) {
        geoObjects[i] = new ymaps.Placemark(points[i], balloonContentHeader[i], getPointOptions[i]);
    }

    /**
     * Можно менять опии кластеризатора после создания.
     */
    clusterer.options.set({
        gridSize: 80,
        clusterDisableClickZoom: false
    });

    /**
     * В кластеризатор ожно добавить javascript-массив меток (е геоколлекцию) или одну метку.
     * @see https://api.yandex.ru/maps/doc/jsapi/2.1/ref/reference/Clusterer.xml#add
     */
    clusterer.add(geoObjects);
    myMap.geoObjects.add(clusterer);
myMap.behaviors.disable('scrollZoom');

if(document.documentElement.clientWidth < 960) {
//myMap.behaviors.disable('drag');
}


    /**
     * Спозиционируем кату так, чтобы на ней были видны все объекты.
     */

   /* myMap.setBounds(clusterer.getBounds(), {
        checkZoomRange: false
    });*/
}
</script>
*

voland

  • Легенда
  • 11028
  • 588 / 112
  • Эта строка съедает место на вашем мониторе
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться