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

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Есть список данных и есть кнопка на тулбаре "Удалить выбранное"...
Подскажите, как удалить только те записи, что отмечены в списке чекбоксами?
*

Kasumi

  • Захожу иногда
  • 70
  • 4 / 0
Вы хотите удалить данные из Joomla и бд? Достаточно удалить их из Joomla, из бд они так же удалятся
Или вы хотите удалить данные непосредственно из бд? Тогда выделите необходимые таблицы и нажмите "удалить выбранное". Если сомневаетесь, то можете прежде сделать резервную копию бд (вкладка экспорт, и сохранить в файл...)
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
Получить все Id записей:

Код: php
$cIds = JRequest::getVar('cid', array(0), '', 'array');

Далее проходим по массиву и удаляем:

Код: php
foreach ($cIds as $id) {
//здесь удаляем запись $id
}
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Вы хотите удалить данные из Joomla и бд? Достаточно удалить их из Joomla, из бд они так же удалятся
Или вы хотите удалить данные непосредственно из бд? Тогда выделите необходимые таблицы и нажмите "удалить выбранное". Если сомневаетесь, то можете прежде сделать резервную копию бд (вкладка экспорт, и сохранить в файл...)
Я вероятно выразил свой вопрос не достаточно понятно...
Написал свой компонент, в админке которого выводится список с данными о поступивших заказах. Первая колонка списка содержит чекбоксы. На тулбаре компонента разместил кнопку "Удалить выбранное"... Некоторые заказы необходимо удалять, т.е. по идее нужно отметить строки, которые требуется удалить. Нажатие обозначенной кнопки должно вызывать задачу (...&task=delete), которая и выполнит удаление выбранных строк... Как составить запрос, чтобы удалить только отмеченные записи?
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Вообщем вот ссылка на статью в моем блоге, где как раз это расписывется.
Пока не получается... а выдаёт ошибку. Блог интересный - ставлю в закладки и буду читать. Спасибо!
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
Цитировать
Блог интересный - ставлю в закладки и буду читать. Спасибо!
Только там по 1.5, но на 1.6/1.7 работать.

Какую ошибку выдает? Если не сложно, то выложите код контроллера и модели. Только закройте тэгом [spoiler.] [/.spoler], чтобы код на всю страницу не был.
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Код
Fatal error: Call to undefined method TableOrderonline::getErrorMsg() in /administrator/components/com_orderonline/models/orderonline.php on line 73

Спойлер
[свернуть]
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
Ругается на $table->getErrorMsg(). Значит Вы программите под 1.7, а в ней уже нет такого метода в классе JTable. Попробуйте его просто поменять на $this->setError('Error during record delete');
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Поменял. Теперь сообщает:
Код
CGCA ADMIN DELETE FAILED[Error during record delete]
...и не удаляет.
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
Поменял. Теперь сообщает:
Код
CGCA ADMIN DELETE FAILED[Error during record delete]
...и не удаляет.
А у Вас вообще создан класс таблицы? Просто в моем примере использовался JTable класс. Если нет, то пробуйте удалять используя JDatabase:

Код: php
public function remove()
{
$cids = JRequest::getVar('cid', array(0), 'post', 'array');

foreach ($cids as $cid) {
$this->_db->setQuery( 'DELETE FROM `#__robo_order` WHERE id  = ' . $this->_db->quote($cid) );

if ( !$this->_db->query() ) {
$this->setError($this->_db->getErrorMsg());
return false;
}
}

return true;
}

Естественно замените в запросе setQuery на свои данные.
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Класс таблицы:
Код
<?php
// No direct access
defined('_JEXEC') or die('Доступ ограничен!');

class TableOrderonline extends JTable
{
    var $id = null;

    function TableOrderonline($db) {
        parent::__construct('#__robo_order', 'oid', $db);
    }
}
?>

Пробовал указанный Вами вариант - говорит всё окей, но записи по прежнему не удаляет.
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
как можно вывести значение $cid в процессе удаления?.. может оно не совпадает со значением поля oid из БД.
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
А так?
Код
$this->_db->setQuery( 'DELETE FROM `#__robo_order` WHERE oid  = ' . $this->_db->quote($cid) );

var_dump($cid); exit();

И ещё $cids проверьте.
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
var_dump($cid); exit();

Выдаёт: string(0) ""
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
вообще везде нулевые значения... вот сам шаблон:
Код
<?php
   defined('_JEXEC') or die('Restricted access');

JToolBarHelper::title(JText::_('Управление заказами'), 'generic.png');
JToolBarHelper::deleteList(JText::_('CGCA ARE YOU SURE'));

JHtml::_('behavior.tooltip');
JHtml::_('behavior.multiselect');

?>
<form action="index.php?option=com_orderonline&view=orderonline" method="post" name="adminForm" id="adminForm">
<table class="adminlist">
<thead>
    <tr>
            <th><input type="checkbox" name="checkall-toggle" value="" onclick="Joomla.checkAll(this);" /></th>
<th width="5"><?php echo JText::_( 'ID' ); ?></th>
<th><?php echo JText::_( 'Дата' ); ?></th>
<th><?php echo JText::_( 'ФИО' ); ?></th>

    <th>MAIL</th>
    <th>URL</th>
    <th>Название сайта</th>
    <th>Краткое описание</th>
    <th>Ключевые слова</th>
    <th>Комментарий к заказу</th>
    <th>Услуга</th>
    <th>Статус оплаты</th>
    </tr>
    </thead>
<tfoot>
  <tr>
    <td colspan="12"><?php echo $this->pagination->getListFooter(); ?></td>
  </tr>
</tfoot>
<tbody>
<?php
$k = 0;
for ($i=0, $n=count( $this->items ); $i < $n; $i++)
{
$row = $this->items[$i];
$checked = JHTML::_('grid.id', $i, $row->id );
?>
<tr class="<?php echo "row$k"; ?>">
    <td><?php echo $checked; ?></td>
        <td><?php echo $row->oid; ?></td>
        <td><?php echo $row->date; ?></td>
        <td><?php echo $row->username; ?></td>
        <td><?php echo $row->mail; ?></td>
        <td><?php echo $row->siteaddr; ?></td>
        <td><?php echo $row->sitename; ?></td>
        <td><?php echo $row->descr; ?></td>
        <td><?php echo $row->keywords; ?></td>
        <td><?php echo $row->comments; ?></td>
        <td><?php echo $row->sid; ?></td>
        <td><?php echo $row->paystate; ?></td>
</tr>
<?php
$k = 1 - $k;
}
?>
</tbody>
</table>
<input type="hidden" name="option" value="com_orderonline" />
<input type="hidden" name="task" value="" />
<input type="hidden" name="boxchecked" value="0" />
<input type="hidden" name="controller" value="orderonline" />
<input type="hidden" name="view" value="orderonline" />
<?php
//Это что то вроде провержи на разбиение страницы.
echo JHTML::_( 'form.token' ); ?>
</form>
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
блин, ошибка была... вместо
Код
$checked = JHTML::_('grid.id', $i, $row->oid );
было:
Код
$checked = JHTML::_('grid.id', $i, $row->id );
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
По видимому $row->id надо заменить на $row->oid

UPDATE:
Вы меня опередили :) Тогда можно использовать и JTable метод ;)
*

At3iSt

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Иногда слона не заметишь :), первый опыт трудный самый...
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
Иногда слона не заметишь :), первый опыт трудный самый...
Это точно. Сам в свое время намучался, да и сейчас  иногда бывают такие затыки ;)  crazy!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Состояние записи - как заставить работать во фронте?

Автор Thomas2000

Ответов: 7
Просмотров: 1292
Последний ответ 26.01.2015, 22:24:06
от b2z
Вывод предыдущей и следующей записи из БД (where?)

Автор ninth

Ответов: 20
Просмотров: 2100
Последний ответ 02.09.2014, 23:54:33
от ninth
Как удалить запись в бд?

Автор x_files_1

Ответов: 1
Просмотров: 1352
Последний ответ 25.06.2014, 21:03:24
от Aleks.Denezh
JInputCookie - возвращение результата записи куков

Автор yunoshev

Ответов: 7
Просмотров: 2283
Последний ответ 29.10.2013, 01:00:54
от Aleks.Denezh