Перейти к содержанию
dojer

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

Рекомендуемые сообщения

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

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

даже не знаю, как лучше...

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

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

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

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!

Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.

Войти

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

×

Важная информация

На нашем сайте используются файлы cookie и происходит обработка некоторых персональных данных пользователей, чтобы улучшить пользовательский интерфейс. Чтобы узнать для чего и какие персональные данные мы обрабатываем перейдите по ссылке. Если Вы нажмете «Я даю согласие», это означает, что Вы понимаете и принимаете все условия, указанные в этом Уведомлении о Конфиденциальности.