Jump to content
Sign in to follow this  
dojer

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

Recommended Posts

ocstore_v1.5.4.1

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

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

Share this post


Link to post
Share on other sites

Если кто-нибудь сталкивался с подобной проблемой, помогите, пожалуйста, разобраться.

Share this post


Link to post
Share on other sites

попробуйте заменить в файле [=== 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;
}

Share this post


Link to post
Share on other sites

да! оно! всё получилось. всем огромное спасибо за помощь!

Share this post


Link to post
Share on other sites

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

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

Share this post


Link to post
Share on other sites

а что там за проблема?

Share this post


Link to post
Share on other sites

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

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

  • +1 1

Share this post


Link to post
Share on other sites

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

Share this post


Link to post
Share on other sites

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

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

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.