Новости Joomla

Вышел WT Quick links v.2.4.0 - релиз модуля для Joomla

Вышел WT Quick links v.2.4.0 - релиз модуля для Joomla.Это модуль-конструктор для быстрого создания набора элементов. Это могут быть ссылки на компоненты Joomla, пункт меню или пользовательская ссылка. Есть условия для исключений показа элементов списка. Вы можете создавать собственные макеты вывода модуля, создавая таким образом почти всё, что угодно: от простого списка ссылок до стены фотографий на главную страницу или ссылки-теги для перелинковки категорий интернет-магазина, список FAQ, табы или аккордеоны. Модуль позволяет выводить изображения, адаптивные изображения, видео, адаптивные видео.v.2.4.0. Что нового?Добавлена поддержка новых компонентов. Добавлены новые типы ссылок и исключений для них: - Phoca Download, - Phoca Gallery, - RadicalMart (@radicalmart).Joomla 6. Успешно протестирована работа модуля на Joomla 6-alpha2.РазработчикамПроведён большой рефакторинг кода. Для типов ссылок созданы классы-драйверы. Теперь для того, чтобы добавить новый тип ссылки в модуль достаточно скопировать класс-образец из
modules/mod_wt_quick_links/src/Driver/Collection и наполнить его данными по образцу, а так же добавить необходимые языковые константы в панели администратора Joomla.Модуль бесплатный. Страница расширенияGitHub расширенияJoomla Extensions Directory👩‍💻 Подпишись на @joomlafeed.#joomla #разработка

Свои типы полей в Joomla.Это большая тема, о которой можно говорить очень много

Свои типы полей в Joomla.Это большая тема, о которой можно говорить очень много

👩‍💻 Свои типы полей в Joomla.Это большая тема, о которой можно говорить очень много. Самое главное, что возможности применения ограничиваются только вашей больной фантазией. Вы строите интерфейс своего модуля или плагина и вам нужно подтянуть данные из сторонней системы (список чего-нибудь по какому-нибудь API), чтобы сохранить выбранный id в Joomla. Или сделать какую-то проверку и в зависимости от неё показать то или иное сообщение пользователю. Для этого подойдут свои пользовательские типы полей. Интерфейс Joomla по большей части описан в XML-файлах. У каждого из них свои параметры. Некоторые не описаны в документации (manual.joomla.org), поэтому самым любопытным будет полезно заглянуть в собственно файлы фреймворка по пути

libraries/src/Form/FormField.php, а так же в
libraries/src/Form/Fields. У каждого класса поля перечислены его специфические свойства, которые можно описывать в XML. А в своём типе поля вы можете устанавливать эти значения программно. В моём модуле WT Quick links под капотом происходят изменения. Теперь для работы (в админке) ему нужен вспомогательный плагин. А в самом модуле нам бы проверить, а не выключен ли он? В Joomla есть тип поля Note - заметка. Его можно использовать для вывода примечаний.

<field type="note"     name="your_note_for_user"     label="Заголовок примечания"     title="Альтернативный способ для заголовка"     description="Текст примечания"     class="col-12 alert alert-info"     heading="h1"     close="true"/>
heading - указывать уровень заголовка.
close - позволяет закрыть это примечание. В классе поля
libraries/src/Form/Field/NoteField.php описана логика вывода. И в принципе оно нам подходит для нашей задачи. Но оно будет выводить сообщение всегда, а нам нужно только тогда, когда плагин отключён.Поэтому берём и создаём свой класс поля, который мы унаследуем от
NoteField. Это значит, что у нас в руках будет весь инструментарий стандартного поля
Note + то, что мы сами добавим. В XML-манифест добавляем наше поле
<field type="systempluginstatus"      name="systempluginstatus"     addfieldprefix="Joomla\Module\Wtquicklinks\Site\Fields"/>
-
type - имя файла и класса,-
addfieldprefix - указываем namespace к нашему классу, может быть любой нам нужный-
name - нельзя полю без имени...Это означает, что Joomla будет использовать класс поля из файла
modules/mod_wt_quick_links/src/Fields/SystempluginstatusField.php.А в классе поля будет написано следующее:
<?php// namespace для атрибута addfieldprefixnamespace Joomla\Module\Wtquicklinks\Site\Fields;// нельзя напрямую обращаться к этому файлуdefined('_JEXEC') or die;// подключаем родительский класс для переопределенияuse Joomla\CMS\Form\Field\NoteField;use Joomla\CMS\Language\Text;use Joomla\CMS\Plugin\PluginHelper;// имя класса и имя файла точь-в-точьclass SystempluginstatusField extends NoteField{     protected $type = 'Systempluginstatus';     protected function getLabel()          {               // если плагин не включён               if(PluginHelper::isEnabled('system','wtquicklinks')) {                    // меняем свойства родительского класса                    $this->class = 'alert alert-danger w-100';                    $this->element['label'] = '⚠️ А-а-а-а!';                    $this->element['description'] = 'Плагин не включён!!';                    // и просто рендерим его с нашими свойствами                    return parent::getLabel();               }          // А иначе всё хорошо, скрываем поле из виду.          $this->parentclass = 'd-none';          return '';     }}
Просто и удобно. И людям приятно, что о них позаботились и рассказали почему что-то не работает.@webtolkru#joomla #php #webdev #разработка

Обновлена информация в Плане развития Joomla

👩‍💻 Обновлена информация в Плане развития Joomla.Здесь собрана информация о датах релизов, описаны принципы версионирования, указаны ответственные за релизы, а так же даты окончания поддержки релизов. Опираясь на эту информацию вы можете планировать развитие ваших интернет-проектов.👩‍💻 Что нового?⛔️ Joomla 4.Дата окончания исправления ошибок безопасности в версии 4.x - 14 октября 2025г. ⚠️ После этой даты Joomla 4 прекратит получать какие-либо обновления, в том числе безопасности - вообще. Рекомендуем обновить ваши сайты до актуальной Joomla 5.✅ Joomla 5.- Дата окончания исправления ошибок в версии 5.x - 13 октября 2026г.- Дата окончания исправления ошибок безопасности в версии 5.x - 12 октября 2027 года.- Текущая актуальная (на момент написания заметки) версия - 5.3.1.- Опубликовано расписание выхода релизов Joomla 5.4. Стабильный релиз ожидается 14 октября 2025 года.✅ Joomla 6.- Дата окончания исправления ошибок в версии 6.x - 17 октября 2028г.- Дата окончания исправления ошибок безопасности в версии 6.x - 16 октября 2029г.- Опубликовано расписание выхода релизов Joomla 6.0. Стабильный релиз ожидается 14 октября 2025 года.- Для разработчиков уже доступна Joomla 6.0.0-alpha1.✅ Joomla! Framework.Обновлена информация о Joomla! Framework - полноценном PHP-фреймворке для разработки. Он в версиях 1.х и 2.х был самостоятельным параллельным проектом, однако начиная с версии Joomla 4.0 стал её основой. Добавлена информация о Joomla! Framework 3.x, который вышел 6 октября 2023 года. Его можно использовать в тех случаях, когда вам в проекте не нужна CMS Joomla целиком.Подробнее на сайте Joomla-сообщества Joomlaportal.ru#joomla #community

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

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
Просмотров: 8295
Последний ответ 01.10.2024, 00:22:40
от jesus
перенесенная Joomla не видит MySQL - в логах MySQL старт нормальный

Автор ommy

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

Автор boq

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

Автор inko_gnito

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

Автор dircell

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