Новости 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

Поток товаров, связанные товары для JoomShopping 5+.

Поток товаров, связанные товары для JoomShopping 5+.

Расширение для JoomShopping 5+, которое позволяет связывать товары между собой на основе общих характеристик, создавая логические группы товаров в каталоге.

Расширение реализует механизм связывания товаров, похожий на стандартный Related Products, но с дополнительной возможностью быстрого подбора товаров по характеристикам.

Принцип работы
- Связывание товаров происходит в полуавтоматическом режиме.
- Администратор выбирает характеристику, по которой нужно сформировать группу товаров (например: модель, серия, объем, тип и т.д.).
- Система фильтрует и показывает список товаров с таким же значением характеристики.
- Администратор выбирает нужные товары из списка для создания связи.
Таким образом сохраняется полный контроль над связями, но значительно упрощается поиск нужных товаров.

Назначение потока товаров в одном товаре является сквозным. Это обеспечивает автоматическую связь и возможность корректировки потока в каждом товаре, который к нему относится.

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

@joomlafeed

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

som555

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
В общем то фильтр какой хотел у меня получился:
Заменил функцию
Код
	public function getDBAccessString($user = null) {

if (is_null($user)) {
$user = $this->get();
}

if ($this->app->joomla->isVersion('1.5')) {
return "access <= ".(int) $user->get('aid', 0);
} else {
$groups = implode(',', $user->getAuthorisedViewLevels());
return "access IN ($groups)";
}
}
на
Код
	public function getDBAccessString($user = null) {
$search = "name LIKE '%".JRequest::getVar('search', '', 'default', 'string')."%' AND ";

if (is_null($user)) {
$user = $this->get();
}

if ($this->app->joomla->isVersion('1.5')) {
$search .= "access <= ".(int) $user->get('aid', 0);
} else {
$groups = implode(',', $user->getAuthorisedViewLevels());
$search .= "access IN ($groups)";
}
return $search;
}
в шаблон категории добавил форму
Код
		<form id="name-filter" action="<?php echo htmlspecialchars(JFactory::getURI()->toString()); ?>" method="post" name="searchForm" accept-charset="utf-8">
<input type="text" name="search" id="zoo-search" value="<?php echo JRequest::getVar('search', '', 'default', 'string');?>" />
<button onclick="this.form.submit();"><?php echo JText::_('Search'); ?></button>
<button onclick="document.getElementById('zoo-search').value='';this.form.submit();"><?php echo JText::_('Reset'); ?></button>
</form>
Но при переходе на другую страницу этого отфильтрованного списка параметр JRequest::getVar('search', '', 'default', 'string') пропадает.
Как параметр JRequest::getVar('search', '', 'default', 'string') передать на другую страницу?
*

som555

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Re: Хочу сделать фильтр в категории
« Ответ #1 : 30.03.2012, 14:55:43 »
Все не так как описал выше.
Задачу решил, пришлось в 3 местах править.
*

gayb

  • Новичок
  • 2
  • 0 / 0
Re: Хочу сделать фильтр в категории
« Ответ #2 : 15.04.2012, 10:04:47 »
Доброо времени суток! А поделитесь правильным кодом - а то очень надо  ^-^
*

-Dima-

  • Захожу иногда
  • 85
  • 14 / 0
Re: Хочу сделать фильтр в категории
« Ответ #3 : 18.04.2012, 22:01:51 »
Вы такого не делайте никогда!! :o
С таким кодом SQL-инъекция Вам обеспечена!
Не хитрыми манипуляциями можно получить пароли всех юзеров.
*

som555

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Re: Хочу сделать фильтр в категории
« Ответ #4 : 20.04.2012, 15:14:43 »
gayb
1. com_zoo\controllers\default.php
заменил
$item_count        = $this->category->id == 0 ? $this->app->table->item->getItemCountFromCategory($this->application->id, $category_id, true) : $this->category->itemCount();
на
$item_count        = $this->app->table->item->getItemCountFromCategory($this->application->id, $category_id, true);
Чтоб каждый раз пересчитывал количество строк.

2. administrator\components\com_zoo\tables\default.php
заменить 2 функции
   public function getByCategory($application_id, $category_id, $published = false, $user = null, $orderby = "", $offset = 0, $limit = 0) {

      // get database
      $db = $this->database;

      // get dates
      $date = $this->app->date->create();
      $now  = $db->Quote($date->toMySQL());
      $null = $db->Quote($db->getNullDate());

      // get item ordering
      $orderby = $this->_getItemOrder($orderby);

      if (isset($_POST['search']))
         $_SESSION['search'] = JString::strtolower($_POST['search']);

      if (isset($_SESSION['searchby'])) {
         if ($_SESSION['searchby'] != $category_id) {
            unset($_SESSION['search']);
            unset($_SESSION['searchby']);
         }
      } else
         $_SESSION['searchby'] = $category_id;

      if (isset($_SESSION['search'])) {
         $search = " AND LOWER(a.name) LIKE ".$db->Quote('%'.$_SESSION['search'].'%');
      } else
         $search = "";

      $query = "SELECT a.*"
         ." FROM ".$this->name." AS a"
         ." LEFT JOIN ".ZOO_TABLE_CATEGORY_ITEM." AS b ON a.id = b.item_id"
         .(isset($orderby['join'])? $orderby['join']: "")
         ." WHERE a.application_id = ".(int) $application_id
         .$search
         ." AND b.category_id ".(is_array($category_id)? " IN (".implode(",", $category_id).")" : " = ".(int) $category_id)
         ." AND ".$this->app->user->getDBAccessString($user)
         .($published == true ? " AND a.state = 1"
         ." AND (a.publish_up = ".$null." OR a.publish_up <= ".$now.")"
         ." AND (a.publish_down = ".$null." OR a.publish_down >= ".$now.")": "")
         ." GROUP BY a.id"
         ." ORDER BY a.priority DESC".(isset($orderby['query'])? ", ".$orderby['query'] : "")
         .(($limit ? " LIMIT ".(int)$offset.",".(int)$limit : ""));

      return $this->_queryObjectList($query);
   }


   public function getItemCountFromCategory($application_id, $category_id, $published = false, $user = null){

      // get database
      $db = $this->database;

      // get dates
      $date = $this->app->date->create();
      $now  = $db->Quote($date->toMySQL());
      $null = $db->Quote($db->getNullDate());

      if (isset($_SESSION['search']))
      $search = " AND LOWER(a.name) LIKE ".$db->Quote('%'.$_SESSION['search'].'%');
      else
      $search = "";

      $query = "SELECT a.*"
         ." FROM ".$this->name." AS a"
         ." LEFT JOIN ".ZOO_TABLE_CATEGORY_ITEM." AS b ON a.id = b.item_id"
         ." WHERE a.application_id = ".(int) $application_id
         .$search
         ." AND b.category_id ".(is_array($category_id)? " IN (".implode(",", $category_id).")" : " = ".(int) $category_id)
         ." AND ".$this->app->user->getDBAccessString($user)
         .($published == true ? " AND a.state = 1"
         ." AND (a.publish_up = ".$null." OR a.publish_up <= ".$now.")"
         ." AND (a.publish_down = ".$null." OR a.publish_down >= ".$now.")": "")
         ." GROUP BY a.id";

      $db->query($query);

      return $db->getNumRows();

   }

3. и в шаблоне templates\default\category.php
добавил форму
      <form id="name-filter" action="<?php echo (substr(JFactory::getURI()->toString(), -1)%10 ? '1' : JFactory::getURI()->toString()); ?>" method="post" name="searchForm" accept-charset="utf-8">
         <input type="text" name="search" id="zoo-search" value="<?php if (isset($_SESSION['search'])) echo $_SESSION['search'];?>" />
         <button onclick="this.form.submit();"><?php echo JText::_('Search'); ?></button>
         <button onclick="document.getElementById('zoo-search').value='';this.form.submit();"><?php echo JText::_('Reset'); ?></button>
      </form>   


ЗЫ: В Joomle есть функции работы с сессиями, позволяющие сделать код более красивый, но тогда я об этом еще не знал. И переменная сессии "search" очень просто названа, может с кем нибудь пересечься.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Дополнительное поле с редактором для категории. Zoo

Автор rch.sergeevich

Ответов: 1
Просмотров: 3574
Последний ответ 22.05.2022, 08:12:16
от arma
Поиск по + фильтр

Автор V1RTUS

Ответов: 3
Просмотров: 3891
Последний ответ 09.08.2021, 00:22:51
от triode-master
Вывод материала категории

Автор face2005

Ответов: 0
Просмотров: 4444
Последний ответ 28.09.2018, 18:26:52
от face2005
[Решено] Как в модуле ZOO Item вывести название и описание категории?

Автор frolov.ar

Ответов: 13
Просмотров: 7568
Последний ответ 01.04.2017, 13:29:52
от rivermc
URL нескольких страниц категории

Автор saschka

Ответов: 2
Просмотров: 2625
Последний ответ 08.02.2017, 13:45:36
от saschka