Новости Joomla

👩‍💻 Joomla включена в программу Google Summer of Code 2026.

👩‍💻 Joomla включена в программу Google Summer of Code 2026.

Google Summer of Code (GSoC) - программа компании Google, которая позволяет участникам программы под руководством опытных наставников писать код для организаций, занимающейся открытым исходным кодом. Joomla принимает участие в этой программе не в первый раз и в 2026 году снова включена в список GSoC. Для программы утверждается список "идей", воплотить которые должны участники под руководством наставников.

Проекты Joomla в рамках программы GSoC 2026.

Проект I: Ajax-бэкенд.
- Действия в административной панели без необходимости обновлять страницу.
- Автоматическое сохранение содержимого во время редактирования.
- Расширенный фильтр - поиск и фильтрация по пользовательским полям.

Проект II: Автоматизация рабочих процессов (workflow + task scheduler).
Joomla имеет функцию процессов и планировщика задач. Теперь эти две функции следует объединить, чтобы пользователь мог настраивать назначенные рабочие процессы таким образом, чтобы переходы выполнялись автоматически, с возможностью точного определения времени. Должна быть возможность создавать циклы или прямые запланированные рабочие процессы. Предполагается, что интерфейс должен учитывать хороший пользовательский опыт, удобство использования и современные стандарты доступности. Ожидается, что будет добавлен интерфейс для управления процессами и их расписанием на страницах категорий и материалов. Так же ожидается, что сторонние компоненты также смогут воспользоваться этим функционалом.

Проект III: Мультикатегории.
В настоящее время Joomla! не позволяет назначать один элемент нескольким категориям. Хотя система тегов часто используется в качестве замены, существует острая потребность в нативной поддержке нескольких категорий, чтобы привести Joomla! в соответствие с другими современными системами управления контентом.

Проект IV: Обучение с подкреплением на основе отзывов переводчиков.
Joomla собирается использовать автоматический перевод документации. В каждом языке есть свои специфические слова, характерные для Joomla. Предполагается обучать языковые модели, используя обратную связь от переводчиков, чтобы постоянно улучшать качество переводов и учитывать специфические языковые особенности Joomla.

Принять участие GSoC 2026
Подробнее о проектах Joomla GSoC 2026
Чат GSoC в Mattermost (международное сообщество Joomla)

Вышли релизы Joomla 6.0.3 и Joomla 5.4.3

Релиз Joomla 6.0.3 и Joomla 5.4.3

Проект Joomla рад сообщить о выпуске Joomla 6.0.3 и Joomla 5.4.3. Это релиз исправлений ошибок и улучшений для серии Joomla 6.0 и Joomla 5.4.

👩‍💻 События плагинов и порядок их срабатывания при работе с пользовательскими полями Joomla и использовании FieldsHelper.

👩‍💻 События плагинов и порядок их срабатывания при работе с пользовательскими полями Joomla и использовании FieldsHelper.

В процессе работы с Joomla бывает необходимо работать с пользовательским интерфейсом более тонко, чем обычно. Все формы Joomla состоят из стандартных полей, содержанием, стилем отображения, состоянием (включено/выключено, доступно для редактирования или нет и т.д.) можно управлять с помощью плагинов. Да и для нестандартных проектов хорошей практикой является создание одного системного или нескольких плагинов групп "под проект", в которых храниться весь "нестандарт".

В этой статье описаны все триггеры, которые вызываются через Event Dispatcher из administrator/components/com_fields/src/Helper/FieldsHelper.php, с привязкой к жизненному циклу (порядку этапов работы запроса), аргументам, изменяемым данным и дальнейшему распространению по Joomla. Это поможет вам работать с Joomla свободнее и не опасаясь при этом потерять изменения при очередном обновлении движка.

Подходы, описанные в статье, полезны в тех случаях, когда вы работаете с данными в com_fields - механизме создания и редактирования пользовательских полей ядра Joomla и при использовании FieldsHelper. Многие сторонние компоненты не используют эту возможность, поэтому данная статья будет полезна лишь частично.

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

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Здравствуйте.

Как выбранному пользователем атрибуту (тип radio) в карточке товара присвоит значение data-bme

Заранее, спасибо.
*

kit2m2

  • Живу я здесь
  • 3372
  • 276 / 0
  • Беру сайты на полное сопровождение
Не меняя ядро компонента, только плагином, который нужно писать...

Насколько я помню - папка tables, файл product.php
Расширения для JoomShopping | Ссылка на Телеграм-канал | Сайты и магазины под ключ: Дизайн, Верстка, Программирование (расширения на заказ), СЕО-оптимизация, Сопровождение, Перенос на Joomla 4+ (5+) и JoomShopping 5+
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
я вообще не понял что нужно
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Не меняя ядро компонента, только плагином, который нужно писать...

Насколько я помню - папка tables, файл product.php

Здесь я смотрел изначально, в коде:

                    $radioseparator = '';
                    if ($jshopConfig->radio_attr_value_vertical) $radioseparator = "<br/>";
                    foreach($options as $k2=>$v2){
                        $options[$k2]->value_name = "<span class='radio_attr_label'>".$v2->value_name."</span>";
                    }

Но это не то. Если здесь править то (data-bme) присваивается всем атрибутам. А надо присвоение только выбранным атрибутам!

Думал что может здесь надо править, но у меня ничего не получилось
components\com_jshopping\js\functions.js

function reloadAttrValue(){
for(var id in attr_value){
if (jQuery("input[name=jshop_attr_id\\["+id+"\\]]").attr("type")=="radio"){
attr_value[id] = jQuery("input[name=jshop_attr_id\\["+id+"\\]]:checked").val();
}else{
attr_value[id] = jQuery("#jshop_attr_id"+id).val();
}
}
}

Я в JS не совсем, а точнее "0"

Может что подскажите.

Спасибо.
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
я вообще не понял что нужно

Что нужно!

Привожу пример...

Не выбран ни один атрибут

<span class="radio_attr_label tooltip-src">XXL</span>
<span class="radio_attr_label tooltip-src">XXXL</span>
<span class="radio_attr_label tooltip-src">XXXXL</span>



Выбран к примеру атрибут XXXL

<span class="radio_attr_label tooltip-src">XXL</span>
<span class="radio_attr_label tooltip-src" data-bme="">XXXL</span>
<span class="radio_attr_label tooltip-src">XXXXL</span>
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Код
jQuery(function($){
    $('body').on('click', '.radio_attr_label', function(){
        $(this).data('bme', '');
    });
});
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Извиняюсь за не компетентность, но если вставляю в

components\com_jshopping\js\functions.js

jQuery(function($){
    $('body').on('click', '.radio_attr_label', function(){
        $(this).data('bme', '');
    });
});

или в  /templates/Ваш-шаблон/html/com_jshopping/product/product_default.php

<script>
jQuery(function($){
    $('body').on('click', '.radio_attr_label', function(){
        $(this).data('bme', '');
    });
});
</script>

Результата ни какого, НЕ срабатывает.

Может я не так что-то делаю?

Направте пожалуйста.

Спасибо.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
сайт покажите
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Код
jQuery(function($){
    $('body').on('click', '.input_type_radio label', function(){
        $(this).find('.radio_attr_label').attr('data-bme', '');
    });
});
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Большое спасибо dmitry_stas.

 Все работает отлично, но есть один нюанс, когда выбираеш один атрибут (XXL) присваивается 'data-bme' а потом другой (XXXL) то другому тоже нормально присваиваеться 'data-bme' но и у первого выбранного атрибута (XXL) присвоинный 'data-bme' остается.

Как сделать чтобы при выборе другого атрибута (XXXL) с первого выбранного атрибута (XXL) присвоинный 'data-bme' удалялся.

И еще раз большое спасибо за помощь!
« Последнее редактирование: 16.01.2019, 03:31:34 от apofisgold »
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Как сделать чтобы при выборе другого атрибута (XXXL) с первого выбранного атрибута (XXL) присвоинный 'data-bme' удалялся.
Есть возможность такой реализации?
 Повторюсь, что я в JS полный "0".
 Буду рад любой помощи...


*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Как добавить при (checked="checked") к класу radio_attr_label  значени data-bme=""?


Структура radio атрибутов такая.

Код
<span id="block_attr_sel_5">

<span class="input_type_radio">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id561" value="61" onclick="setAttrValue('5', this.value);">
<label for="jshop_attr_id561">
<span class="radio_attr_label tooltip-src">
<img src="1.jpg" alt="">
Светло-серый
</span>
</label>
</span>

<span class="input_type_radio">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id562" value="62" onclick="setAttrValue('5', this.value);">
<label for="jshop_attr_id562">
<span class="radio_attr_label tooltip-src">
<img src="1.jpg" alt="">
Светло-серый
</span>
</label>
</span>

<span class="input_type_radio">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id563" value="63" onclick="setAttrValue('5', this.value);">
<label for="jshop_attr_id563">
<span class="radio_attr_label tooltip-src">
<img src="1.jpg" alt="">
Светло-серый
</span>
</label>
</span>

</span>

Это выбранный атрибут (checked="checked")
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id562" value="62" checked="checked" onclick="setAttrValue('5', this.value);">

Это НЕ выбранный атрибут (БЕЗ checked="checked")
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id562" value="627а" onclick="setAttrValue('5', this.value);">

-------

<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id561" value="61" onclick="setAttrValue('5', this.value);">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id562" value="62" checked="checked" onclick="setAttrValue('5', this.value);">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id563" value="63" onclick="setAttrValue('5', this.value);">

-------

Как сделать чтобы активному атрибуту со значением (checked="checked") к класу <span class="radio_attr_label tooltip-src"> добавлялось значение ( 'data-bme' )
Чтото на подобие
-------

<span id="block_attr_sel_5">

<span class="input_type_radio">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id561" value="61" onclick="setAttrValue('5', this.value);">
<label for="jshop_attr_id561">
<span class="radio_attr_label tooltip-src">
<img src="1.jpg" alt="">
Светло-серый
</span>
</label>
</span>

<span class="input_type_radio">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id562" value="62" checked="checked" onclick="setAttrValue('5', this.value);">
<label for="jshop_attr_id562">
<span class="radio_attr_label tooltip-src" data-bme="">
<img src="1.jpg" alt="">
Светло-серый
</span>
</label>
</span>

<span class="input_type_radio">
<input type="radio" name="jshop_attr_id[5]" id="jshop_attr_id563" value="63" onclick="setAttrValue('5', this.value);">
<label for="jshop_attr_id563">
<span class="radio_attr_label tooltip-src">
<img src="1.jpg" alt="">
Светло-серый
</span>
</label>
</span>

</span>



Решение изложенное решение Не подходит, так-как через onclick срабатывает через раз...
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Если я не ошибаюсь за (checked="checked") отвечает js по пути:

components\com_jshopping\js\functions.js

function reloadAttrValue(){
for(var id in attr_value){
if (jQuery("input[name=jshop_attr_id\\["+id+"\\]]").attr("type")=="radio"){
attr_value[id] = jQuery("input[name=jshop_attr_id\\["+id+"\\]]:checked").val();
}else{
attr_value[id] = jQuery("#jshop_attr_id"+id).val();
}
}
}
*

apofisgold

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Здесь есть кто?
*

nevigen

  • Moderator
  • 10451
  • 863 / 25
  • http://n*****n.com
всегда кто-то есть.
Профессиональные / Бесплатные решения для JoomShopping
Не лечи бесплатно, ибо тот, кто лечится бесплатно, рано или поздно перестает ценить свое здоровье,
а тот, кто лечит бесплатно, рано или поздно перестает ценить результаты своего труда/ (с) Гиппократ?
Не ищите ответов, ищите решение !
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Одинаковое значение value для все атрибутов

Автор Dolphin4ik_1

Ответов: 0
Просмотров: 971
Последний ответ 27.08.2019, 13:56:37
от Dolphin4ik_1
Сортировка заказов по выбранному критерию (по умолчанию)

Автор Accentor

Ответов: 6
Просмотров: 1745
Последний ответ 31.07.2018, 06:32:19
от semak85
Неправильное значение итоговой суммы в корзине

Автор Playmaker8

Ответов: 8
Просмотров: 2171
Последний ответ 23.05.2018, 23:00:34
от warlife
Получить значение кастомного поля JoomShopping в файле шаблона

Автор Ragnarok

Ответов: 2
Просмотров: 1060
Последний ответ 07.05.2018, 18:57:52
от Ragnarok
Дефолтное значение для поля "Описание"

Автор viteg

Ответов: 13
Просмотров: 1605
Последний ответ 31.05.2016, 13:29:05
от SmokerMan