Новости Joomla

SW JProjects v.2.5.0 - компонент каталога цифровых проектов на Joomla

SW JProjects v.2.5.0 - компонент каталога цифровых проектов на Joomla

👩‍💻 SW JProjects v.2.5.0 - компонент каталога цифровых проектов на Joomla.Компонент - менеджер цифровых проектов для Joomla! CMS. Компонент обеспечивает создание каталога цифровых проектов и предоставляет возможность скачивания, в том числе с использованием лицензионных ключей.👩‍💻 v.2.5.0. Что нового?Схемы структур данных для серверов обновлений. Теперь с SW JProjects вы может создавать сервер обновлений не только для расширений Joomla, но и свои собственные. Например, вам нужно, чтобы структура данных сервера обновлений была другая и формат должен быть, например, не XML, а JSON. Формирование структуры данных для сервера обновлений расширений Joomla вынесено в отдельный плагин. Вы можете создать свой собственный плагин и реализовать в нём нужную вам структуру данных, добавив или наоборот исключив отображаемые данные. Сервер обновлений в компоненте по-прежнему отображает информацию о списке проектов и их версиях, о конкретном проекте и его changelog.Можно выбрать схему данных сервера обновлений глобально для всего компонента, выбрать другую схему данных для категории проектов, а так же выбрать схему в каждом проекте.

Разработчикам в качестве образца можно посмотреть плагин схемы данных для Joomla в составе компонента или же плагин-образец JSON-схемы на GitHub.
Группа плагинов swjprojects. Для нужд компонента создана группа плагинов swjprojects. В частности, в этой группе находится плагин структуры данных Joomla расширений для сервера обновлений.Изменение языковых констант. Изменены некоторые языковые константы в панели администратора. Если вы делали переопределение констант - переопределите их снова.👩‍💻 Joomla 6. Внесены изменения для корректной установки и работы компонента на Joomla 6. Компонент успешно протестирован на Joomla 6-beta2.Минимальная версия Joomla - 5. Подняты минимальные системные требования: Joomla 5.0.0 и PHP 8.1.
- Страница расширения👉 Плагин-образец кастомной JSON-схемы данных для сервера обновлений на GitHub.- GitHub расширения- Документация на GitHub- Joomla Extensions Directory#joomla #расширения

Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод...

Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод...

👩‍💻 Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод triggerEvent(), с помощью которого раньше вызывались события для плагинов. Теперь чтобы в своём коде вызвать событие для плагина и получить от него результаты нужно:- создать объект класса события- передать в него параметры

use Joomla\CMS\Event\AbstractEvent;use Joomla\CMS\Factory;use Joomla\CMS\Plugin\PluginHelper;// Грузим плагины нужных группPluginHelper::importPlugin('system');// Создаём объект события$event = AbstractEvent::create('onAfterInitUniverse', [    'subject' => $this,    'data'    => $data, // какие-то данные    'article' => $article, // ещё материал вдовесок    'product' => $product, // и товаров подвезли]);// Триггерим событиеFactory::getApplication()->getDispatcher()->dispatch(    $event->getName(), // Тут можно строку передать 'onAfterInitUniverse'    $event);// Получаем результаты// В случае с AbstractEvent это может быть не 'result',// а что-то ещё - куда сами отдадите данные.// 2-й аргумент - значение по умолчанию, // если не получены результаты$results = $event->getArgument('result', []);
Плюсы такого подхода - вам не нужно запоминать порядок аргументов и проверять их наличие. Если вы написали свой класс события, то в плагине можно получать аргументы с помощью методов $event->getArticle(), $event->getData(), $event->getProduct() и подобными - реализуете сами под свои нужды. Если такой класс события написали, то создаёте экземпляр своего класса события и укажите его явно в аргументе eventClass
use Joomla\Component\MyComponent\Administrator\Event\MyCoolEvent;$event = MyCoolEvent::create('onAfterInitUniverse', [    'subject'    => $this,    'eventClass' => MyCoolEvent::class, // ваш класс события    'data'       => $data, // какие-то данные    'article'    => $article, // ещё материал вдовесок    'product'    => $product, // и товаров подвезли]);
Ожидаемо, что класс вашего события будет расширять AbsractEvent или другие классы событий Joomla.🙁 Есть неприятный нюанс - нельзя просто так вызывать событие и ничего не передать в аргументы. Аргумент subject обязательный. Но если вы всё-таки не хотите туда ничего передавать - передайте туда пустой stdClass или объект Joomla\registry\Registry.
@joomlafeed#joomla #php #webdev

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

At3iSt

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

Kasumi

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

b2z

  • Глобальный модератор
  • 7287
  • 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

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

At3iSt

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

b2z

  • Глобальный модератор
  • 7287
  • 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

  • Глобальный модератор
  • 7287
  • 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

  • Глобальный модератор
  • 7287
  • 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

  • Глобальный модератор
  • 7287
  • 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

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

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

At3iSt

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

b2z

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

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

Автор Thomas2000

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

Автор ninth

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

Автор x_files_1

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

Автор yunoshev

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