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

Ragnarok

  • Захожу иногда
  • 64
  • 1 / 0
Всем привет!
На Joomla 2.5.28 и JoomShopping 3.11.4 я делал порядок сортировки товаров на сайте по новому полю в Производителях (числовое поле). Но делал это через правку ядра. Все работало. Результатом всего этого было то, что, товары определенного производителя сортировались в зависимости от значения этого поля. То есть, я мог легко товары определенного производителя поднять на самый верх, либо выводить после товаров другого определенного производителя. Чем ниже значение, тем выше товары этого производителя. Что делал:

1. Создал поле "Порядок сортировки товаров" в шаблоне /administrator/components/com_jshopping/views/manufacturer/tmpl/edit.php
2. Создал поле в БД в таблице #__jshopping_manufacturers
2. В файле /administrator/components/com_jshopping/controllers/manufacturers.php в методе save(); дописал:
Код
$post['мое_новое_поле_'.$lang->language] = JRequest::getVar('мое_новое_поле'.$lang->id,'','post',"string", 2);
3. В файле /components/com_jshopping/tables/manufacturer.php в методе getDescription(); добавил:
Код
$мое_новое_поле = $lang->get('мое_новое_поле');
$this->мое_новое_поле= $this->$мое_новое_поле;
4. В файле /components/com_jshopping/lib/jtableauto.php в методе getBuildQueryOrderListProduct(); написал:
Код
$order_query = "ORDER BY `мое_новое_поле_ru-RU` ASC, man.`name_ru-RU`, pr_cat.product_ordering ASC";

Все отлично работало.

Теперь у меня Joomla! 3.9.23 и JoomShopping 4.18.5. На этот раз пытаюсь сделать через плагин, и ничего не выходит. Что делал?
1. Плагин при установке создает новую таблицу #__jshopping_manufacturers_extra_fields, где есть id производителя, название и значение этого нового поля
2. В шаблоне /administrator/templates/isis/html/com_jshopping/manufacturer/edit.php создал это поле
3. В плагине:
Код
defined( '_JEXEC' ) or die;

class plgJshoppingproductsManufacturers_Extra_Fields extends JPlugin {

function __construct(&$subject, $config){
parent::__construct($subject, $config);
}

public function onBeforeEditManufacturers(&$view){
$мое_новое_поле = $man_extra[$view->manufacturer->manufacturer_id]->мое_новое_поле;
$view->manufacturer->мое_новое_поле = $мое_новое_поле;
}

public function onBeforeSaveManufacturer(&$post){
$мое_новое_поле = $post['мое_новое_поле'];

$db = JFactory::getDbo();
$query = "INSERT INTO `#__jshopping_manufacturers_extra_fields` (`man_id`, `man_name`, `мое_новое_поле`)
VALUES ('".$man_id."', '".$man_name."', '".$мое_новое_поле."')
ON DUPLICATE KEY UPDATE `man_id` = '".$man_id."', `man_name` = '".$man_name."', `мое_новое_поле` = '".$мое_новое_поле."'";
$db->setQuery($query);
$db->query();
}

public function onBuildQueryOrderListProduct($order, $orderby, &$adv_from, &$order_query, $order_original){
$order_query = "ORDER BY мое_новое_поле ASC, name, pr_cat.product_ordering ASC";
}
}
В базу поле сохраняется, в админке выводится, тут все ок. Но на сайте выдает ошибку: 1054 Unknown column 'мое_новое_поле' in 'order clause'

Что я делаю не так?
Заранее благодарен.
« Последнее редактирование: 26.12.2020, 11:21:13 от Ragnarok »
*

kit2m2

  • Живу я здесь
  • 3264
  • 267 / 0
  • Беру сайты на полное сопровождение
Что это вообще такое pr_cat.product_ordering? Судя по псевдониму - pr_cat - это обращение к таблице #__jshopping_products_to_categories в которой нет "вашего поля".

В сообщении Вам ясно написано: Не соблюдено условие для сортировки
Расширения для JoomShopping | Расширения на заказ | Сайты и магазины под ключ: Дизайн, Верстка, Программирование, СЕО-оптимизация, Сопровождение, Перенос на Joomla 4+ и JoomShopping 5+
*

Ragnarok

  • Захожу иногда
  • 64
  • 1 / 0
Что это вообще такое pr_cat.product_ordering? Судя по псевдониму - pr_cat - это обращение к таблице #__jshopping_products_to_categories в которой нет "вашего поля".

В сообщении Вам ясно написано: Не соблюдено условие для сортировки
А откуда берутся эти псевдонимы? Как узнать, какой псевдоним у определенной таблицы?
*

kit2m2

  • Живу я здесь
  • 3264
  • 267 / 0
  • Беру сайты на полное сопровождение
А откуда берутся эти псевдонимы?
Они задаются в запросе к таблице при выборки данных для страницы (смотреть нужно в ядре компонента, как формируется запрос)

Подробнее о псевдонимах здесь
Расширения для JoomShopping | Расширения на заказ | Сайты и магазины под ключ: Дизайн, Верстка, Программирование, СЕО-оптимизация, Сопровождение, Перенос на Joomla 4+ и JoomShopping 5+
*

Ragnarok

  • Захожу иногда
  • 64
  • 1 / 0
Методом научного тыка решил вопрос следующим образом. В плагине:
Код
<?php
defined( '_JEXEC' ) or die;

class plgJshoppingproductsManufacturers_Extra_Fields extends JPlugin {

function __construct(&$subject, $config){
parent::__construct($subject, $config);
}

public function onBeforeEditManufacturers(&$view){
$мое_новое_поле = $man_extra[$view->manufacturer->manufacturer_id]->мое_новое_поле;
$view->manufacturer->мое_новое_поле = $мое_новое_поле;
}

public function onBeforeSaveManufacturer(&$post){
$мое_новое_поле = $post['мое_новое_поле'];

$db = JFactory::getDbo();
$query = "INSERT INTO `#__jshopping_manufacturers_extra_fields` (`man_id`, `man_name`, `мое_новое_поле`)
VALUES ('".$man_id."', '".$man_name."', '".$мое_новое_поле."')
ON DUPLICATE KEY UPDATE `man_id` = '".$man_id."', `man_name` = '".$man_name."', `мое_новое_поле` = '".$мое_новое_поле."'";
$db->setQuery($query);
$db->query();
}

public function onBuildQueryOrderListProduct($order, $orderby, &$adv_from, &$order_query, $order_original){
$adv_from = " LEFT JOIN `#__jshopping_manufacturers_extra_fields` AS mef ON prod.product_manufacturer_id = `man_id`";
$order_query = "ORDER BY mef.мое_новое_поле ASC, mef.man_name ASC, pr_cat.product_ordering ASC";
}
}
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

JoomShopping плагин подмены статического текста JoomShopping на материалы Joomla

Автор sergeytolkachyov

Ответов: 6
Просмотров: 769
Последний ответ 01.03.2024, 13:41:05
от sergeytolkachyov
WT JShopping cart save плагин брошенных корзин пользователей. JoomShopping 5.3+

Автор sergeytolkachyov

Ответов: 4
Просмотров: 293
Последний ответ 01.03.2024, 12:29:46
от kit2m2
WT Modules in Jshopping positions - плагин вставки модулей Joomla в JoomShopping

Автор sergeytolkachyov

Ответов: 2
Просмотров: 888
Последний ответ 06.02.2024, 18:15:15
от sergeytolkachyov
Модуль карусели товаров JoomShopping на Swiper.js для Joomla

Автор sergeytolkachyov

Ответов: 1
Просмотров: 369
Последний ответ 10.01.2024, 19:54:00
от sergeytolkachyov
Фильтр товаров для JoomShopping 5

Автор Lemonez

Ответов: 5
Просмотров: 506
Последний ответ 04.01.2024, 22:06:03
от Biss