Новости Joomla

👩‍💻 WT CDEK library v.1.3.0 - обновление PHP SDK для Joomla + CDEK.

👩‍💻 WT CDEK library v.1.3.0 - обновление PHP SDK для Joomla + CDEK.

Небольшая нативная PHP Joomla библиотека для работы с API v.2 службы доставки CDEK. Библиотека представляет собой клиент для авторизации в CDEK API по OAuth, работы с некоторыми методами API: получения ряда данных и расчета стоимости доставки. Поддерживается Joomla 4.2.7 и выше.

В пакет входят:
- библиотека Webtolk/Cdekapi
- системный плагин System - WT Cdek для хранения настроек и AJAX-интеграций
- task-плагин Task - Update WT Cdek data для обновления локальных копий справочников CDEK по расписанию
- web asset с официальным JavaScript-виджетом СДЭК

👉 v.1.3.0. Что нового?
- Полный рефакторинг библиотеки. Библиотека переработана в entity-based API с фасадом Cdek и отдельным слоем запросов. Обратная совместимость не нарушена, поэтому версия библиотеки - 1.3.0.
- Добавлена поддержка новых разделов API СДЭК. Добавлена поддержка новых разделов API СДЭК: webhooks, prealert, печатные формы, payment, passport, reverse, intakes и других сущностей.
- Улучшена интеграция с Joomla.
Улучшена интеграция с Joomla: installer script для layouts, новые поля Joomla Form для тарифов и обновлённые js виджета CDEK.
- документация библиотеки. Все методы библиотеки подробно описаны, а так же текст документации собран в отдельной папке в git репозитории и будет опубликован на сайте.

Библиотека эта нужна для разработчиков, создающих свои расширения для интеграции Joomla и курьерской службы CDEK.

Страница расширения
GitHub расширения

@joomlafeed

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

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
Просмотров: 1326
Последний ответ 26.01.2015, 22:24:06
от b2z
Вывод предыдущей и следующей записи из БД (where?)

Автор ninth

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

Автор x_files_1

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

Автор yunoshev

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