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

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

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

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

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

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

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

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


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

никак

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

вот и все.

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

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


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

Тоже столкнулся с такой проблемой, когда перегонял товары из другого движка в 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']);
                       }
               }
       }
}
?>

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


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

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

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

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

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

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

Войти

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

Войти

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

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

×

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

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