Jump to content
Search In
  • More options...
Find results that contain...
Find results in...
  • Sign Up

Проблема с категориями/подкатегориями


Recommended Posts

Guest

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

При открытии сайта спортивного питания в категории "аксессуары" и "аминокислоты" есть одинаковая подкатегория "Линия Body Shaper".

Самое интересное, что урл открывается правильный, а вот информация на нем...

Так вот независимо от того, по какой именно из них кликнуть откроется все-равно первая... Как можно это исправить не назначая разных псевдонимов? :blink:

Link to post
Share on other sites

никак

"псевдоним" один - ссылка на первую категорию с ним.

вот и все.

если не хотите полностью менять Псевдонимы для категорий, то добавляйте ID-категории при формировании SEO-URL

Link to post
Share on other sites

Тоже столкнулся с такой проблемой, когда перегонял товары из другого движка в opencart.

Решил это на уровне патча к конкретно моей задаче.

Чтобы бы не терзать БД лишними запросами, добавил столбец 'parent_id' в таблицу oc_url_alias после 'keyword'

в кототорый заносил значения паралеллельно добавлению категорий напрямую в БД опенкарта через скрипт.

Чтобы обойтись без доп. столбца - в seo_url.php нужно добавить несколько доп. запросов к БД,

тогда все будет работать и в стандартной комплектации опенкарта.

ALTER TABLE oc_url_alias ADD parent_id INT AFTER keyword

Изменил запрос к БД и добавил пару строк в catalog/controller/common/seo_url.php

Код с изменениями:

<?php
class ControllerCommonSeoUrl extends Controller {
       public function index() {
               if (isset($this->request->get['_route_'])) {
                       $parts = explode('/', $this->request->get['_route_']);

                       $parent_category = 0;      // ADDED

       foreach ($parts as $part) {

       // $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "url_alias WHERE keyword = '" . $this->db->escape($part) . "'");

       // CHANGED TO:

       $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "url_alias WHERE keyword = '" . $this->db->escape($part) . "' AND parent_id = '".$parent_category."'");

                               if ($query->num_rows) {
                                       $url = explode('=', $query->row['query']);

                                       if ($url[0] == 'product_id') {
                                               $this->request->get['product_id'] = $url[1];
                                               $parent_category = $url[1];
                                       }

                                       if ($url[0] == 'category_id') {
                                               if (!isset($this->request->get['path'])) {
                                                       $this->request->get['path'] = $url[1];

                                               } else {
                                                       $this->request->get['path'] .= '_' . $url[1];
                                               }

                                               $parent_category = $url[1];               // ADDED
                                       }

                                       if ($url[0] == 'manufacturer_id') {
                                               $this->request->get['manufacturer_id'] = $url[1];

                                       }

                                       if ($url[0] == 'information_id') {
                                               $this->request->get['information_id'] = $url[1];

                                       }
                               } else {
                                       $this->request->get['route'] = 'error/not_found';
                               }
                       }

                       if (isset($this->request->get['product_id'])) {
                               $this->request->get['route'] = 'product/product';
                       } elseif (isset($this->request->get['path'])) {
                               $this->request->get['route'] = 'product/category';
                       } elseif (isset($this->request->get['manufacturer_id'])) {
                               $this->request->get['route'] = 'product/manufacturer';
                       } elseif (isset($this->request->get['information_id'])) {
                               $this->request->get['route'] = 'information/information';
                       }

                       if (isset($this->request->get['route'])) {
                               return $this->forward($this->request->get['route']);
                       }
               }
       }
}
?>

Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
  • Recently Browsing   0 members

    No registered users viewing this page.

×
×
  • Create New...

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.