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

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Тут без вмешательства в код ядра не обошлось, но у меня все характеристики должны быть с мультивыбором и других вариантов я не увидел, так-что хакаем ядро:

Админка

1. \administrator\components\com_jshopping\controllers\products.php
Меняем строку
Код: php
$obj->values = JHTML::_('select.genericlist', array_merge($f_option, $tmp), $name, '', 'id', 'name', $product->$name);

На
Код: php
$selected = explode(',', $product->$name);
                $obj->values = JHTML::_('select.genericlist', array_merge($f_option, $tmp), $name.'[]', 'class="inputbox" size="10" multiple="multiple"', 'id', 'name', $selected);

2. После строки
Код: php
$dispatcher->trigger( 'onBeforeDisplaySaveProduct', array(&$post) );

Вставляем

Код: php
$newPost = array();
        foreach($post as $k => $v){
            if(is_array($v) && strpos($k,'extra_field')!== false){
                $newPost[$k] = implode(',', $v);
            }
            else{
                $newPost[$k] = $v;
            }
        }

3. БД сделать запрос
Код: sql
ALTER TABLE `jos_jshopping_products` CHANGE `extra_field_1` `extra_field_1` VARCHAR( 255 ) NOT NULL
естественно поменять префикс таблиц на свой,и ко всем полям, содержащим в названии extra_field. Иначе будет запоминаться только первое выбранное значение.

Морда
\components\com_jshopping\tables\product.php

Код: php
        foreach($fields as $field_id){
            $field_name = "extra_field_".$field_id;
            if ($this->$field_name!=0){
                $rows[] = array("name"=>$listfield[$field_id]->name, "value"=>$fieldvalues[$this->$field_name]);
            }
        }

Меняем на
Код: php
        foreach($fields as $field_id){
            $field_name = "extra_field_".$field_id;
            if ($this->$field_name!=0){
                //экомир добавил мультихарактеристики
                $fvalues = explode(',', $this->$field_name);
                if(count($fvalues)>1){
                    $fstring = array();
                    foreach($fvalues as $fvalue){
                        $fstring[] = $fieldvalues[$fvalue];
                    }
                    $fstring = implode(', ', $fstring);
                    $rows[] = array("name"=>$listfield[$field_id]->name, "value"=>$fstring);
                }
                else{
                    $rows[] = array("name"=>$listfield[$field_id]->name, "value"=>$fieldvalues[$this->$field_name]);
                }

            }
        }

Отбор товаров по мультихарактеристикам


Скоро
« Последнее редактирование: 03.01.2012, 14:36:13 от Arkadiy »
*

nevigen

  • Moderator
  • 10451
  • 863 / 25
  • http://n*****n.com
Т.е. чтобы правильно понимать...
Это возможнсть присвоения нескольких характеристик товару имено в админке ?
А сама возможность фильтеринга с фронта будет "Скоро" ?

Супер !
Давно думал об этом.. но.. уповать приходилось только на разработчиков..
Однако теперь понимаю, что не только на них ;)
Профессиональные / Бесплатные решения для JoomShopping
Не лечи бесплатно, ибо тот, кто лечится бесплатно, рано или поздно перестает ценить свое здоровье,
а тот, кто лечит бесплатно, рано или поздно перестает ценить результаты своего труда/ (с) Гиппократ?
Не ищите ответов, ищите решение !
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Вышла 3.3.0, если бы не этот факт, то доделал бы завтра, но завтра придется делать ревизию компонента и совмещать правки и новый компонент, но думаю завтра-же и решу.
*

fliginskih

  • Захожу иногда
  • 197
  • 15 / 1
блин, ребята, давайте правильно выражаться!
ибо я боюсь неправильно вас понять.
не путайте характеристику с опцией ! есть характеристика "цвет" и ее опции "зеленый, синий и т.д."

так что же вы имеете в виду?
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
У меня терминология от вирта осталась, там все несколько по-другому, привыкнешь.
*

fliginskih

  • Захожу иногда
  • 197
  • 15 / 1
проверим, испытаем...
*

RUslankaRU

  • Новичок
  • 4
  • 0 / 0
Большое спасибо за проделанную работу, очень помогло.
Правда, есть нюанс. Не работал скрипт, пока не внесла после пункта 2 в вашем посте строку:
Код
 $post = $NewPost; 

Поиск joomla_module_JoomShopping-Search-3.1.2 прекрасно работает с вашим патчем.
*

leopoldus

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
 делаю SQL запрос
Код
ALTER TABLE `d1x3p_jshopping_products` CHANGE `extra_field_1` `extra_field_1` VARCHAR( 255 ) NOT NULL
и мне пишет #1054 - Unknown column 'extra_field_1' in 'd1x3p_jshopping_products' Прилагаю скриншот. Подскажите пожалуйста
*

Linfuby

  • Завсегдатай
  • 1242
  • 176 / 0
  • Всё просто...
делаю SQL запрос
Код
ALTER TABLE `d1x3p_jshopping_products` CHANGE `extra_field_1` `extra_field_1` VARCHAR( 255 ) NOT NULL
и мне пишет #1054 - Unknown column 'extra_field_1' in 'd1x3p_jshopping_products' Прилагаю скриншот. Подскажите пожалуйста
Заведите сначала в настройках магазина одну характеристику.
Немного воображения и логики, и любая проблема становится решенной.
Кривые решения - дают кривой результат!
Решения для JoomShopping
Благодарности и поддержка принимаются по след. реквизитам:
Яндекс.Деньги - 41001751720054
*

leopoldus

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
Цитировать
Заведите сначала в настройках магазина одну характеристику.
Сделал - все осталось также.
 У меня были с десяток характеристик, но я все же создал новую и подключил в настройка.

 Получается что сам мультивыбор в характеристиках есть, он выберает с контролом несколько пунктов, НО НЕ СОХРАНЯЕТСЯ
*

leopoldus

  • Осваиваюсь на форуме
  • 17
  • 0 / 0
Цитировать
и ко всем полям, содержащим в названии extra_field.

Как это сделать в PHP My Admin
*

Linfuby

  • Завсегдатай
  • 1242
  • 176 / 0
  • Всё просто...
Данный SQL-запрос увеличивает ширину строки до 255 символов.
Посмотрите в таблице d1x3p_jshopping_products последние поля. Если есть характеристики, то это обычно extra_field_idхарактеристики.
Так вот для каждой характеристики которая будет "мультиселект", надо сделать такой запрос. А лучше использовать улучшенную версию Мультивыбора.
Немного воображения и логики, и любая проблема становится решенной.
Кривые решения - дают кривой результат!
Решения для JoomShopping
Благодарности и поддержка принимаются по след. реквизитам:
Яндекс.Деньги - 41001751720054
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться