Новости Joomla

Вышел плагин социальных кнопок для Joomla - JL Like 5.1.0

Вышел плагин социальных кнопок для Joomla - JL Like 5.1.0

Вышел плагин социальных кнопок для Joomla - JL Like 5.1.0.JL Like — современный плагин для Joomla, который добавляет стильные кнопки "Поделиться" и счетчики лайков популярных соцсетей. Не использует внешние скрипты, что обеспечивает максимальную скорость и безопасность.👩‍💻 v.5.1.0. Что нового?Виджет предварительного просмотра- Добавлен интерактивный предпросмотр социальных кнопок в админ панели- Живое обновление настроек в реальном времени- Переключение между мобильным и десктопным видомУлучшенная мобильная поддержка- Оптимизированные размеры кнопок для мобильных устройств- Адаптивные стили для лучшего отображения на смартфонах- Touch-friendly интерфейсСовременная архитектура- Внедрена система Web Assets для Joomla 4/5- Оптимизированная загрузка ресурсов с атрибутом defer- Улучшенная производительностьТехнические улучшения- Добавлен новый метод getBaseUri() для лучшей обработки URL- Обновлена поддержка JoomShopping и ZOO компонентов- Улучшена совместимость с Joomla 5.xСкачать релиз с GitHubСтраница расширения@joomlafeed#расширения

Новый способ добавления и рендера полей в 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.

<?php // В Controller/View добавляем поля $this->form ->addControlField('task', '') ->addControlField('return', $input->getBase64('return', '')) ->addControlField('forcedLanguage', $forcedLanguage);

А в layout'е просто используем метод

renderControlFields()

<?php // В layout формы echo $this->form->renderControlFields();

Многие компоненты ядра уже используют этот подход. Соответствующий PR был принят в Joomla 5.3 осенью 2024г.

Смотреть Pull Request

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

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
В пункте в меню, привязанном к конкретному материалу, клик на кнопку "изменить" откроет модалку с материалом, как в своем компоненте открыть такую по простой ссылке? все параметры материала заранее известны




могу просто вызвать модалку, в которой вставлю iframe, но ссылок на странице 50шт (вид списка в админке), хотелось бы по уму, как?
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
до чего дошел прогресс...

в начале подключаем
Код
JHtml::_('jquery.framework');
JHtml::_('behavior.core');
JHtml::_('behavior.multiselect');
JHtml::_('behavior.formvalidator');
JHtml::_('formbehavior.chosen', 'select');
JHtml::_('behavior.keepalive');
JHtml::_('script', 'system/modal-fields.js', array('version' => 'auto', 'relative' => true));


генерим модалку и скрипт для работы с нею
Код
<div id="ModalEditArticle_jform_request_id" tabindex="-1" class="modal hide fade jviewport-width80" data-backdrop="static" data-keyboard="false">
<div class="modal-header">
<h3>Изменить материал</h3>
</div>
<div class="modal-body jviewport-height70"></div>
<div class="modal-footer">
<a role="button" class="btn" aria-hidden="true" onclick="window.processModalEdit(this, 'jform_request_id', 'edit', 'article', 'cancel', 'item-form'); return false;">Закрыть</a>
<a role="button" class="btn btn-primary" aria-hidden="true" onclick="window.processModalEdit(this, 'jform_request_id', 'edit', 'article', 'save', 'item-form'); return false;">Сохранить и закрыть</a>
<a role="button" class="btn btn-success" aria-hidden="true" onclick="window.processModalEdit(this, 'jform_request_id', 'edit', 'article', 'apply', 'item-form'); return false;">Сохранить</a></div>
</div>
<input type="hidden" id="jform_request_id_name" value="" />
<input type="hidden" id="jform_request_id_id"  class="required modal-value" data-required="1" name="jform[request][id]" value="" /></div>
</div>

<script>
function jSelectArticle_jform_request_id(id, title, catid, object, url, language) {
window.processModalSelect('Article', 'jform_request_id', id, title, catid, object, url, language);
}
jQuery(document).ready(function($) {
$('#ModalEditArticle_jform_request_id').on('show.bs.modal', function() {
        $('body').addClass('modal-open');
        var modalBody = $(this).find('.modal-body');
        modalBody.find('iframe').remove();
        modalBody.prepend('<iframe class="iframe jviewport-height70" src="index.php?option=com_content&amp;view=article&amp;layout=modal&amp;tmpl=component&amp;<?php echo JSession::getFormToken(); ?>=1&amp;task=article.edit&amp;id=' + document.getElementById("jform_request_id_id").value + '" name="Изменить материал" height="400px" width="800px"></iframe>');
    }).on('shown.bs.modal', function() {
        var modalHeight = $('div.modal:visible').outerHeight(true),
            modalHeaderHeight = $('div.modal-header:visible').outerHeight(true),
            modalBodyHeightOuter = $('div.modal-body:visible').outerHeight(true),
            modalBodyHeight = $('div.modal-body:visible').height(),
            modalFooterHeight = $('div.modal-footer:visible').outerHeight(true),
            padding = document.getElementById('ModalEditArticle_jform_request_id').offsetTop,
            maxModalHeight = ($(window).height()-(padding*2)),
            modalBodyPadding = (modalBodyHeightOuter-modalBodyHeight),
            maxModalBodyHeight = maxModalHeight-(modalHeaderHeight+modalFooterHeight+modalBodyPadding);
        var iframeHeight = $('.iframe').height();
        if (iframeHeight > maxModalBodyHeight){
            $('.modal-body').css({'max-height': maxModalBodyHeight, 'overflow-y': 'auto'});
            $('.iframe').css('max-height', maxModalBodyHeight-modalBodyPadding);
        }
    }).on('hide.bs.modal', function () {
        $('body').removeClass('modal-open');
        $('.modal-body').css({'max-height': 'initial', 'overflow-y': 'initial'});
        $('.modalTooltip').tooltip('destroy');
    });
});
</script>

ссылка, которая будет вызывать модалку
Код
<a href="#ModalEditArticle_jform_request_id" data-toggle="modal" role="button" onclick="document.getElementById('jform_request_id_id').value=<?php echo $item->article_id; ?>;document.getElementById('jform_request_id_name').value=jQuery(this).text;"><?php echo $this->escape($item->article_title); ?></a>

что ж как все просто-то...
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Есть реализация вызова модального окна через SqueezeBox от Aleks.Denezh в его каркасе компонента.
генерим модалку и скрипт для работы с нею
Не нужно генерить скрипта - он уже есть в коробке. Достаточно набросать шаблон модалки и отрендерить его посредством JHtmlBootstrap
Код
echo JHtml::_('bootstrap.renderModal', ID_контейнера, параметры, HTML_вывод_шаблона_модалки);
Не будь паразитом, сделай что-нибудь самостоятельно!
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
можно и так наверное, мне просто надо было максимально быстро (создать компонент за 2 часа - как угнать тачку за 60 сек ))) ) и я тупо скопипизжил все из поля выбора материала для меню, уже с фронта админки дернул, тот самый паршийвый случай, когда и так сойдет ) работает же )
*

Aleks.Denezh

  • Живу я здесь
  • 3404
  • 428 / 4
« Последнее редактирование: 04.05.2018, 22:31:23 от Aleks.Denezh »
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Саш, ты невнимателен: мне это надо в модели списка, где просто ссылка, а не поле
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Ваш первый пост немного о другом: там есть кнопка, которая вызывает список материалов. Поле, о котором писал Aleks.Denezh, выводит такую кнопку.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
могу просто вызвать модалку, в которой вставлю iframe, но ссылок на странице 50шт (вид списка в админке), хотелось бы по уму, как?
*

Aleks.Denezh

  • Живу я здесь
  • 3404
  • 428 / 4
« Последнее редактирование: 04.05.2018, 22:31:19 от Aleks.Denezh »
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
это вот сюда вот ты мне поле предлагаешь запихнуть?

*

Aleks.Denezh

  • Живу я здесь
  • 3404
  • 428 / 4
« Последнее редактирование: 04.05.2018, 22:31:11 от Aleks.Denezh »
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
первый скрин - пример, где это можно найти, чтобы отвечающий на вопрос мог конкретно посмотреть, как работает и что требуется
последний скрин - самописный компонент, где требуется реализовать

та ну ладно, не парься, уже сделал, работает, все довольны
*

Aleks.Denezh

  • Живу я здесь
  • 3404
  • 428 / 4
« Последнее редактирование: 04.05.2018, 22:31:07 от Aleks.Denezh »
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
в списке
а вида редактирования вообще нет, весь компонент - только 1 список в админке и 1 аякс-модель на фронте
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
это вот сюда вот ты мне поле предлагаешь запихнуть?
А ну тогда да, ваш способ - единственный верный, IMHO. Можно его реализовать через JHtmlBootstrap, как я писал, но суть та же.
Не будь паразитом, сделай что-нибудь самостоятельно!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вызов формы компонента в pop-up, при клике по ссылке из любого места

Автор SkyAn

Ответов: 1
Просмотров: 616
Последний ответ 01.03.2021, 04:08:48
от gartes
Как подменить контент-плагином шаблон материала?

Автор Efanych

Ответов: 29
Просмотров: 1052
Последний ответ 30.03.2018, 16:11:57
от Efanych
Плагин добавления пользовательских полей в форму редактирования материала

Автор zeus07

Ответов: 0
Просмотров: 1057
Последний ответ 03.03.2017, 03:43:12
от zeus07
Вызов внешней функции из админки

Автор denism300

Ответов: 8
Просмотров: 1282
Последний ответ 15.12.2016, 15:37:33
от denism300
вызов setRedirect() из модели

Автор denism300

Ответов: 2
Просмотров: 1255
Последний ответ 11.12.2016, 21:16:12
от denism300