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

[Решено] В расширенном поиске, не учитывается параметр выбранной категории.


dojer

Recommended Posts

ocstore_v1.5.4.1

В расширенном поиске, не учитывается параметр выбранной категории. Т.е. к примеру, если выбрать определенную категорию товаров, и написать название товаров, то поиск выдаёт товары из всех категорий с таким названием.

Подскажите, пожалуйста, как это можно исправить?

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


попробуйте заменить в файле [=== catalog/model/catalog/product.php ===] метод

public function getProducts($data = array()) {

на

public function getProducts($data = array()) {
if ($this->customer->isLogged()) {
$customer_group_id = $this->customer->getCustomerGroupId();
} else {
$customer_group_id = $this->config->get('config_customer_group_id');
} 

$cache = md5(http_build_query($data));

$product_data = $this->cache->get('product.' . (int)$this->config->get('config_language_id') . '.' . (int)$this->config->get('config_store_id') . '.' . (int)$customer_group_id . '.' . $cache);

if (!$product_data) {
$sql = "SELECT p.product_id, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id)"; 

if (!empty($data['filter_category_id'])) {
$sql .= " LEFT JOIN " . DB_PREFIX . "product_to_category p2c ON (p.product_id = p2c.product_id)"; 
}

$sql .= " WHERE pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'"; 

if (!empty($data['filter_name']) || !empty($data['filter_tag'])) {
$sql .= " AND (";
if (!empty($data['filter_category_id'])) {
$sql .= "(";
}

if (!empty($data['filter_name'])) { 
if (!empty($data['filter_description'])) {
$sql .= "LCASE(pd.name) LIKE '%" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "%' OR MATCH(pd.description) AGAINST('" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "')";
} else {
$sql .= "LCASE(pd.name) LIKE '%" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "%'";
}
}

if (!empty($data['filter_name']) && !empty($data['filter_tag'])) {
$sql .= " OR ";
}

if (!empty($data['filter_tag'])) {
//$sql .= "MATCH(pd.tag) AGAINST('" . $this->db->escape(utf8_strtolower($data['filter_tag'])) . "')";
// [w]
$tags = explode(',', $data['filter_tag']);
$tagSql = array();
foreach($tags as $tag) {
$tagSql[] = "(
(pd.`tag` LIKE '".$this->db->escape(utf8_strtolower($tag))."')
OR
(pd.`tag` LIKE '".$this->db->escape(utf8_strtolower($tag)).",%')
OR
(pd.`tag` LIKE '%, ".$this->db->escape(utf8_strtolower($tag)).",%')
OR
(pd.`tag` LIKE '%, ".$this->db->escape(utf8_strtolower($tag))."')
)";
}

//echo implode('OR', $tagSql);
//die();

$sql .= implode('OR', $tagSql);
}

$sql .= ")";

if (!empty($data['filter_name'])) {
$sql .= " OR LCASE(p.model) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
}

if (!empty($data['filter_name'])) {
$sql .= " OR LCASE(p.sku) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
} 

if (!empty($data['filter_name'])) {
$sql .= " OR LCASE(p.upc) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
} 

if (!empty($data['filter_name'])) {
$sql .= " OR LCASE(p.ean) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
}

if (!empty($data['filter_name'])) {
$sql .= " OR LCASE(p.jan) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
}

if (!empty($data['filter_name'])) {
$sql .= " OR LCASE(p.isbn) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
} 

if (!empty($data['filter_name'])) {
$sql .= " OR LCASE(p.mpn) = '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "'";
}

if (!empty($data['filter_category_id'])) {
$sql .= ")";
}
}

if (!empty($data['filter_category_id'])) {
if (!empty($data['filter_sub_category'])) {
$implode_data = array();

$implode_data[] = (int)$data['filter_category_id'];

$this->load->model('catalog/category');

$categories = $this->model_catalog_category->getCategoriesByParentId($data['filter_category_id']);

foreach ($categories as $category_id) {
$implode_data[] = (int)$category_id;
}

$sql .= " AND p2c.category_id IN (" . implode(', ', $implode_data) . ")"; 
} else {
$sql .= " AND p2c.category_id = '" . (int)$data['filter_category_id'] . "'";
}
} 

if (!empty($data['filter_manufacturer_id'])) {
$sql .= " AND p.manufacturer_id = '" . (int)$data['filter_manufacturer_id'] . "'";
}

$sql .= " GROUP BY p.product_id";

$sort_data = array(
'pd.name',
'p.model',
'p.quantity',
'p.price',
'rating',
'p.sort_order',
'p.date_added'
); 

if (isset($data['sort']) && in_array($data['sort'], $sort_data)) {
if ($data['sort'] == 'pd.name' || $data['sort'] == 'p.model') {
$sql .= " ORDER BY LCASE(" . $data['sort'] . ")";
} else {
$sql .= " ORDER BY " . $data['sort'];
}
} else {
$sql .= " ORDER BY p.sort_order"; 
}

if (isset($data['order']) && ($data['order'] == 'DESC')) {
$sql .= " DESC, LCASE(pd.name) DESC";
} else {
$sql .= " ASC, LCASE(pd.name) ASC";
}

if (isset($data['start']) || isset($data['limit'])) {
if ($data['start'] < 0) {
$data['start'] = 0;
} 

if ($data['limit'] < 1) {
$data['limit'] = 20;
} 

$sql .= " LIMIT " . (int)$data['start'] . "," . (int)$data['limit'];
}

/*
echo "<pre>";
print_r($sql);
echo "</pre>";
die();
*/

$product_data = array();

$query = $this->db->query($sql);

foreach ($query->rows as $result) {
$product_data[$result['product_id']] = $this->getProduct($result['product_id']);
}

$this->cache->set('product.' . (int)$this->config->get('config_language_id') . '.' . (int)$this->config->get('config_store_id') . '.' . (int)$customer_group_id . '.' . $cache, $product_data);
}

return $product_data;
}

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

не пробовал решение от sv2109.

в моем варианте еще решена проблема поиска по тэгам, состоящим из нескольких слов через пробел.

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

при тэге "телевизор samsung" и поиске по нему найдутся все товары в которых будет "одно из слов", а не "все словосочетание" (т.е. по факту - все телевизоры и все товары фирмы samsung).

в моем варианте - только те, у которых есть тэг "телевизор samsung".

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

  • 2 weeks later...

А как сделать, чтобы при нажатии на введенное слово поиск на главной это слово удалялось, а при повторном нажатии на введенные уже слова - не удалялись введенные данные. Сейчас поле ввода очищается по факту установки курсора. Как это убрать?

И еще как сделать, чтобы слово "Поиск" не передавалось на страницу поиска, при нажатии на главной сразу на значок поиска?

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


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

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

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

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

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

Вхід

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

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

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

×
×
  • Створити...

Important Information

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