Jump to content
Sign in to follow this  
trubadan

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

Recommended Posts

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

 

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

 

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

Share this post


Link to post
Share on other sites

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

 

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

 

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

 

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

 

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 файл, что б он делал изменения, а не делать это вручную

Share this post


Link to post
Share on other sites

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

 

Замена происходит в файле - 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)
);
Edited by trubadan

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
You are posting as a guest. If you have an account, please sign in.
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Sign in to follow this  

  • Recently Browsing   0 members

    No registered users viewing this page.

×

Important Information

On our site, cookies are used and personal data is processed to improve the user interface. To find out what and what personal data we are processing, please go to the link. If you click "I agree," it means that you understand and accept all the conditions specified in this Privacy Notice.