Перейти до вмісту
Пошук в
  • Детальніше...
Шукати результати, які ...
Шукати результати в ...

Помогите с сортировкой товаров в категориях по количеству.


trubadan

Recommended Posts

Всем доброго здоровья и с наступающим.

 

Как сделать так, чтобы в категориях, товары с нулевым количеством выводились в конце списка?

 

Заранее спасибо.

Надіслати
Поділитися на інших сайтах


Всем доброго здоровья и с наступающим.

 

Как сделать так, чтобы в категориях, товары с нулевым количеством выводились в конце списка?

 

Заранее спасибо.

 

Открываем файл:

 

catalog/model/catalog/product.php

 

Ищем:

$sql .= " ORDER BY LCASE(" . $data['sort'] . ")";

Заменяем:

$sql .= " ORDER BY (p.quantity > 0) DESC, LCASE(" . $data['sort'] . ")";

Затем ищем:

$sql .= " ORDER BY (CASE WHEN special IS NOT NULL THEN special WHEN discount IS NOT NULL THEN discount ELSE p.price END)";

Заменяем:

$sql .= " ORDER BY (p.quantity > 0) DESC, (CASE WHEN special IS NOT NULL THEN special WHEN discount IS NOT NULL THEN discount ELSE p.price END)";

Затем ищем:

$sql .= " ORDER BY " . $data['sort'];

Заменяем на:

$sql .= " ORDER BY (p.quantity > 0) DESC," . $data['sort'];

И, наконец-то ищем:

$sql .= " ORDER BY p.sort_order";

И заменяем на:

$sql .= " ORDER BY (p.quantity > 0) DESC, p.sort_order";

Конечно, лучше написать OcMode файл, что б он делал изменения, а не делать это вручную

Надіслати
Поділитися на інших сайтах

Спасибо, разобрался сам, но сделал немного по другому и тоже работает.

 

Замена происходит в файле - catalog/controller/catalog/catalog.php

 

Находим:

if (isset($this->request->get['sort'])) {
} else {
$sort = 'p.sort_order';
}

if (isset($this->request->get['order'])) {
$order = $this->request->get['order'];
} else {
$order = 'ASC';
}

Меняем на:

if (isset($this->request->get['sort'])) {
	$sort = $this->request->get['sort'];
} else {
	$sort = 'p.quantity';
}

if (isset($this->request->get['order'])) {
	$order = $this->request->get['order'];
} else {
	$order = 'DESC';
}

Еще находим:

$data['sorts'][] = array(
	'text'  => $this->language->get('text_default'),
	'value' => 'p.sort_order-ASC',
	'href'  => $this->url->link('product/category', 'path=' . $this->request->get['path'] . '&sort=p.sort_order&order=ASC' . $url)
);

Снова меняем:

$data['sorts'][] = array(
'text'  => $this->language->get('text_default'),
'value' => 'p.duantity-DESC',
'href'  => $this->url->link('product/category', 'path=' . $this->request->get['path'] . '&sort=p.quantity&order=DESC' . $url)
);
Змінено користувачем trubadan
Надіслати
Поділитися на інших сайтах


Створіть аккаунт або увійдіть для коментування

Ви повинні бути користувачем, щоб залишити коментар

Створити обліковий запис

Зареєструйтеся для отримання облікового запису. Це просто!

Зареєструвати аккаунт

Вхід

Уже зареєстровані? Увійдіть тут.

Вхід зараз
  • Зараз на сторінці   0 користувачів

    • Ні користувачів, які переглядиють цю сторінку
×
×
  • Створити...

Important Information

На нашому сайті використовуються файли cookie і відбувається обробка деяких персональних даних користувачів, щоб поліпшити користувальницький інтерфейс. Щоб дізнатися для чого і які персональні дані ми обробляємо перейдіть за посиланням . Якщо Ви натиснете «Я даю згоду», це означає, що Ви розумієте і приймаєте всі умови, зазначені в цьому Повідомленні про конфіденційність.