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

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Модифицировал VirtueMart, добавил дополнительные страницы.
Так вот на одной из них у меня загвоздка.

Как правильно сделать вложенный цикл и вывести данные?

То есть, на странице должна быть такая таблица:

Заказ    Дата                         Сумма             Скидка    Доставка    Сумма к оплате       Статус
№17      12 января 2009 года      18 711 руб.    15%          300 руб.   20 011 руб.                В обработке

А под ней подробные данные о заказе:

фото 1, характеристика товара 1, цена 1
фото 2, характеристика товара 2, цена 2

Если таких заказов два и больше, соответственно под этой таблицей должна появиться ещё одна такая же таблица для второго заказа.

Предполагаю, что здесь нужен вложенный цикл.
for {

     for{

         }
    }

Пытался сделать что-то в этом роде.


       $user =& JFactory::getUser();
       $db =& JFactory::getDBO();
       $query = 'SELECT order_id AS oid, cdate AS cd, order_subtotal AS ost, order_discount AS od, order_shipping AS osh, order_total AS ot, SUM( order_subtotal ) AS sum_ost, SUM( order_discount ) AS sum_od, SUM( order_shipping ) AS sum_osh, SUM( order_total ) AS sum_ot FROM `jos_vm_orders` WHERE `user_id` = "131" AND `order_status` =  "ЗО" OR  `order_status` =  "ОД" group by cdate';
       $db->setQuery($query);
       $rows = $db->loadObjectList();
 
       foreach ( $rows as $row )



Помогите реализовать данный цикл на php. Своими силами и знаниями не получается.
Заранее спасибо!
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
на выходе получается массив из строк, где повторяются данные номер заказа, дата, сумма и характеристики. При этом если в заказе два товара - строк 2, если три - 3 и так далее?
Если да, то я бы делал элементарно (недавно так в одном модуле прекрасно заработало)
делаем счетчиком
Код: php
$i = '0';
foreach ( $rows as $row ) {
 if ($i == '0') {
 echo 'Поля из запроса, которые отвечают за основную информацию о заказе';
 } else {
 echo 'фото 1, характеристика товара 1, цена 1';
 }
$I++;
}
То есть первой строкой мы показываем только основные информации и эта строка у нас будет на выходе одна, остальными выводим столько строк сколько и подробных данных
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Спасибо! Всё работает.  :D :D :D
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Поспешил я сказать, что всё работает.
Первое echo выводится как положено, а echo в else не выводится.
Здесь получается, если i будет не равно 0, только тогда срабатывает else.

Может что-то в этом роде сделать?
Код
<?php
$i = '0';
$k = '0';
foreach ( $rows as $row ) {
if ($i == '0') {
 echo $row->значения. 'Поля из запроса, которые отвечают за основную информацию о заказе';
    }
$I++;
elseif ($k == '0') {
 echo '$row->фото 1, характеристика товара 1, цена 1';
        break;
    }
}
endforeach;
?>

То есть два цикла получается.
1 выводит Поля из запроса, которые отвечают за основную информацию о заказе
2 фото 1, характеристика товара 1, цена 1
      фото 2, характеристика товара 2, цена 2

1 выводит Поля из запроса, которые отвечают за основную информацию о заказе2
2-й фото 1, характеристика товара 1, цена 1
      фото 2, характеристика товара 2, цена 2
« Последнее редактирование: 31.12.2009, 04:40:47 от dmonco »
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Прошу прощения, оказывается соврал, в своем модуле делал немного по другому
Код: php
$i = 0;
foreach ( $rows as $row )
{
if ($i == '0') {
    echo 'Первая строка';
} else {}
$i++;
}
$ii = 0;
foreach ( $rows as $row2 )
{
if ($ii != '0') {
    echo 'прочие строки';
} else {}
$ii++;
}
Сейчас смотрю с ужасом и не понимаю зачем я так делал, но то что работало - помню точно. Суть аналогична, пример на сайте в модуле новостей, первый материал выводится полностью с картинкой и текстом, остальные 3-5 только заголовками, все это дело получается из одного запроса
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Я уже так пробовал. Не вышло.  >:(

Структура страницы такая:

Таблица 1 (которая не повторяется, а выводится один раз)

Таблица 2 //здесь общая информация заказа
(начало)

  Таблица 3 //подробные данные заказа

Таблица 2 //здесь продолжение общей информации о заказе
(конец)

..вроде должно было работать  :'(
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Может дело в запросе в базу?

У меня на каждый foreach свой запрос:
1       
 
Код
$user =& JFactory::getUser();
$db =& JFactory::getDBO();
$query = 'SELECT order_id AS oid, cdate AS cd, order_subtotal AS ost, order_discount AS od, order_shipping AS osh, order_total AS ot, order_status AS ostat, SUM( order_subtotal ) AS sum_ost, SUM( order_discount ) AS sum_od, SUM( order_shipping ) AS sum_osh, SUM( order_total ) AS sum_ot FROM `jos_vm_orders` WHERE `user_id` = '.$auth['user_id'].' AND `order_status` =  "ЗО" OR  `order_status` =  "ОД" group by cdate';
$db->setQuery($query);
$rows = $db->loadObjectList();
     

2
Код
$user =& JFactory::getUser();
$db2 =& JFactory::getDBO();
$query2 = 'SELECT i.order_id, i.order_item_name AS item, o.order_id, o.user_id FROM jos_vm_order_item AS i INNER JOIN jos_vm_orders AS o ON i.order_id = o.order_id WHERE o.user_id = '.$auth['user_id'].' group by i.order_item_name';
$db2->setQuery($query2);
$rows2 = $db2->loadObjectList()
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
мне трудно дать внятное решение не зная какие именно данные находятся в таблицах и выбираются запросами
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как заставить Joomla 1.5 работать на сервере с MySQL версии 5.7 и выше?

Автор Palomnik

Ответов: 14
Просмотров: 9274
Последний ответ 01.10.2024, 00:22:40
от jesus
перенесенная Joomla не видит MySQL - в логах MySQL старт нормальный

Автор ommy

Ответов: 23
Просмотров: 6244
Последний ответ 23.01.2018, 11:20:48
от altvvc
MAMP и MySQL

Автор boq

Ответов: 7
Просмотров: 6256
Последний ответ 08.01.2017, 02:25:47
от SeBun
The MySQL adapter "mysqli" is not available

Автор inko_gnito

Ответов: 13
Просмотров: 37712
Последний ответ 27.09.2016, 20:58:27
от lukinalek
[Решено] Unable to connect to the database:Could not connect to MySQL

Автор dircell

Ответов: 82
Просмотров: 170759
Последний ответ 22.01.2016, 19:22:10
от Template_user