Всем привет!
На 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'
Что я делаю не так?
Заранее благодарен.