Новости Joomla

👩‍💻 SW JProjects v.2.6.1 - компонент каталога расширений для веб-приложений.

👩‍💻 SW JProjects v.2.6.1 - компонент каталога расширений для веб-приложений.

Компонент позволяет сделать свой мини-Joomla Extensions Directory - каталог расширений для CMS (не только для Joomla) или файлов. Есть возможность скачивания по лицензионным ключам создания кастомных схем данных для сервера обновлений.

👩‍💻 v.2.6.1. Что нового?
- Правки наследования схем серверов обновлений. Улучшена логика наследования схем серверов обновлений для проектов компонент - категория - проект.
- Не стабильные релизы в сервере обновлений. Теперь в данные сервера обновлений попадают все версии (alpha, beta и т.д.), а не только stable.
- Косметические изменения. В шаблоне по умолчанию сделаны замены некоторых CSS-классов, уточнено присвоение атрибутов loading=lazy и fetchpriority.
- Рефакторинг и правки кода. Текущее обновление кодовой базы.
- Исправление ошибок.

👩‍💻 Больше спасибо за помощь в тестировании участникам нашего сообщества Александру Новикову (@pro_portal) и Александру Судьбинову (@alexrevo).

- Страница расширения
- GitHub расширения
- Joomla Extensions Directory

@joomlafeed

Событие Pizza, Bugs & Fun - 29-30 января 2026 года.

Событие Pizza, Bugs & Fun  - 29-30  января 2026 года.

Уже несколько лет в мире Joomla проводятся мероприятия "Pizza, Bugs & Fun" (#PBF), где каждый может посвятить несколько часов своего мозгового времени тому, чтобы наша любимая CMS стала ближе к идеалу.

Ссылки на видео и статьи из этого поста рассказывает об организационных вопросах, которые пригодятся для участия в PBF, а так же что и как делать.

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

Каждый помогает тем, что он умеет:

  • кто-то пишет недостающую документацию,
  • кто-то пишет код,
  • кто-то тестирует как исправлены ошибки или сделан новый функционал.

На сайте события есть карта, можно "захостить" свою локацию. Практически все движки в мире развиваются за счёт спонсирующих их компаний. Joomla одна из немногих, где развитие идёт только усилиями международного сообщества энтузиастов.

https://www.youtube.com/watch?v=a-FuVKXg_Uw 

На момент написания данного поста в репозитории Joomla 810 открытых Issue (как правило это баги) и 236 Pull request (PR, исправление багов и новый функционал). Все PR обязательно тестируются минимум двумя участниками сообщества, дабы в конечный код движка не проскочила ошибка.

Если каждый из участников только нашего сообщества сделает даже одно тестирование, то, боюсь, PR и Issue на всех не хватит 😀 И ничего не останется нашим коллегам из международных Joomla-чатов.

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

Ragnarok

  • Захожу иногда
  • 64
  • 1 / 0
Всем привет!
На Joomla 2.5.28 и JoomShopping 3.11.4 я делал порядок сортировки товаров на сайте по новому полю в Производителях (числовое поле). Но делал это через правку ядра. Все работало. Результатом всего этого было то, что, товары определенного производителя сортировались в зависимости от значения этого поля. То есть, я мог легко товары определенного производителя поднять на самый верх, либо выводить после товаров другого определенного производителя. Чем ниже значение, тем выше товары этого производителя. Что делал:

1. Создал поле "Порядок сортировки товаров" в шаблоне /administrator/components/com_jshopping/views/manufacturer/tmpl/edit.php
2. Создал поле в БД в таблице #__jshopping_manufacturers
2. В файле /administrator/components/com_jshopping/controllers/manufacturers.php в методе save(); дописал:
Код
$post['мое_новое_поле_'.$lang->language] = JRequest::getVar('мое_новое_поле'.$lang->id,'','post',"string", 2);
3. В файле /components/com_jshopping/tables/manufacturer.php в методе getDescription(); добавил:
Код
$мое_новое_поле = $lang->get('мое_новое_поле');
$this->мое_новое_поле= $this->$мое_новое_поле;
4. В файле /components/com_jshopping/lib/jtableauto.php в методе getBuildQueryOrderListProduct(); написал:
Код
$order_query = "ORDER BY `мое_новое_поле_ru-RU` ASC, man.`name_ru-RU`, pr_cat.product_ordering ASC";

Все отлично работало.

Теперь у меня Joomla! 3.9.23 и JoomShopping 4.18.5. На этот раз пытаюсь сделать через плагин, и ничего не выходит. Что делал?
1. Плагин при установке создает новую таблицу #__jshopping_manufacturers_extra_fields, где есть id производителя, название и значение этого нового поля
2. В шаблоне /administrator/templates/isis/html/com_jshopping/manufacturer/edit.php создал это поле
3. В плагине:
Код
defined( '_JEXEC' ) or die;

class plgJshoppingproductsManufacturers_Extra_Fields extends JPlugin {

function __construct(&$subject, $config){
parent::__construct($subject, $config);
}

public function onBeforeEditManufacturers(&$view){
$мое_новое_поле = $man_extra[$view->manufacturer->manufacturer_id]->мое_новое_поле;
$view->manufacturer->мое_новое_поле = $мое_новое_поле;
}

public function onBeforeSaveManufacturer(&$post){
$мое_новое_поле = $post['мое_новое_поле'];

$db = JFactory::getDbo();
$query = "INSERT INTO `#__jshopping_manufacturers_extra_fields` (`man_id`, `man_name`, `мое_новое_поле`)
VALUES ('".$man_id."', '".$man_name."', '".$мое_новое_поле."')
ON DUPLICATE KEY UPDATE `man_id` = '".$man_id."', `man_name` = '".$man_name."', `мое_новое_поле` = '".$мое_новое_поле."'";
$db->setQuery($query);
$db->query();
}

public function onBuildQueryOrderListProduct($order, $orderby, &$adv_from, &$order_query, $order_original){
$order_query = "ORDER BY мое_новое_поле ASC, name, pr_cat.product_ordering ASC";
}
}
В базу поле сохраняется, в админке выводится, тут все ок. Но на сайте выдает ошибку: 1054 Unknown column 'мое_новое_поле' in 'order clause'

Что я делаю не так?
Заранее благодарен.
« Последнее редактирование: 26.12.2020, 11:21:13 от Ragnarok »
*

kit2m2

  • Живу я здесь
  • 3372
  • 276 / 0
  • Беру сайты на полное сопровождение
Что это вообще такое pr_cat.product_ordering? Судя по псевдониму - pr_cat - это обращение к таблице #__jshopping_products_to_categories в которой нет "вашего поля".

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

Ragnarok

  • Захожу иногда
  • 64
  • 1 / 0
Что это вообще такое pr_cat.product_ordering? Судя по псевдониму - pr_cat - это обращение к таблице #__jshopping_products_to_categories в которой нет "вашего поля".

В сообщении Вам ясно написано: Не соблюдено условие для сортировки
А откуда берутся эти псевдонимы? Как узнать, какой псевдоним у определенной таблицы?
*

kit2m2

  • Живу я здесь
  • 3372
  • 276 / 0
  • Беру сайты на полное сопровождение
А откуда берутся эти псевдонимы?
Они задаются в запросе к таблице при выборки данных для страницы (смотреть нужно в ядре компонента, как формируется запрос)

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

Ragnarok

  • Захожу иногда
  • 64
  • 1 / 0
Методом научного тыка решил вопрос следующим образом. В плагине:
Код
<?php
defined( '_JEXEC' ) or die;

class plgJshoppingproductsManufacturers_Extra_Fields extends JPlugin {

function __construct(&$subject, $config){
parent::__construct($subject, $config);
}

public function onBeforeEditManufacturers(&$view){
$мое_новое_поле = $man_extra[$view->manufacturer->manufacturer_id]->мое_новое_поле;
$view->manufacturer->мое_новое_поле = $мое_новое_поле;
}

public function onBeforeSaveManufacturer(&$post){
$мое_новое_поле = $post['мое_новое_поле'];

$db = JFactory::getDbo();
$query = "INSERT INTO `#__jshopping_manufacturers_extra_fields` (`man_id`, `man_name`, `мое_новое_поле`)
VALUES ('".$man_id."', '".$man_name."', '".$мое_новое_поле."')
ON DUPLICATE KEY UPDATE `man_id` = '".$man_id."', `man_name` = '".$man_name."', `мое_новое_поле` = '".$мое_новое_поле."'";
$db->setQuery($query);
$db->query();
}

public function onBuildQueryOrderListProduct($order, $orderby, &$adv_from, &$order_query, $order_original){
$adv_from = " LEFT JOIN `#__jshopping_manufacturers_extra_fields` AS mef ON prod.product_manufacturer_id = `man_id`";
$order_query = "ORDER BY mef.мое_новое_поле ASC, mef.man_name ASC, pr_cat.product_ordering ASC";
}
}
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Плагин уведомлений о заказах в телеграмм для JoomShopping

Автор thevaca

Ответов: 0
Просмотров: 333
Последний ответ 10.11.2025, 14:11:40
от thevaca
WT JoomShopping Favorite - кнопки избранного в категории товаров и карточке тов

Автор sergeytolkachyov

Ответов: 26
Просмотров: 36339
Последний ответ 14.10.2025, 12:54:56
от sergeytolkachyov
Модуль карусели товаров JoomShopping на Swiper.js для Joomla

Автор sergeytolkachyov

Ответов: 2
Просмотров: 2475
Последний ответ 04.07.2025, 10:30:36
от sergeytolkachyov
[Решено] Сбросить счётчик ID товаров JoomShopping

Автор goga_pgasovav

Ответов: 3
Просмотров: 1674
Последний ответ 13.02.2025, 00:11:20
от goga_pgasovav
Плагин обновления цен и остатков товаров JoomShopping из CSV

Автор sergeytolkachyov

Ответов: 0
Просмотров: 1876
Последний ответ 24.12.2024, 14:50:42
от sergeytolkachyov