Opencart使用Category作为商店的父级(多商店系统)

时间:2013-07-05 16:36:13

标签: php list menu opencart categories

Hy all,

我正在开设多家商店网站。

主要商店是this。第二个商店(相同的数据库,多商店)是this with uid 4

我已经为第二家商店增加了一个包含多个孩子,有大孩子等等的类别......

我的问题非常简单,如何将类别(uid 355)设为该商店的父类别而不是uid 0

我稍后会使用VQMOD,但我现在直接在文件中插入代码,以便快速编程/调试

我正在更改的文件位于:[root]/catalog/module/category.php

我已更改此代码:

public function getCategories($parent_id = 0) {
        $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "category c LEFT JOIN " . DB_PREFIX . "category_description cd ON (c.category_id = cd.category_id) LEFT JOIN " . DB_PREFIX . "category_to_store c2s ON (c.category_id = c2s.category_id) WHERE c.parent_id = '" . (int)$parent_id . "' AND cd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND c2s.store_id = '" . (int)$this->config->get('config_store_id') . "'  AND c.status = '1' ORDER BY c.sort_order, LCASE(cd.name)");

        return $query->rows;
    }

对此:

public function getCategories($parent_id = 0) {
        if( $this->config->get('config_store_id') == 4 && $parent_id == 0 ){
            $parent_id = 355;
            echo "test1";
        }
        $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "category c LEFT JOIN " . DB_PREFIX . "category_description cd ON (c.category_id = cd.category_id) LEFT JOIN " . DB_PREFIX . "category_to_store c2s ON (c.category_id = c2s.category_id) WHERE c.parent_id = '" . (int)$parent_id . "' AND cd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND c2s.store_id = '" . (int)$this->config->get('config_store_id') . "'  AND c.status = '1' ORDER BY c.sort_order, LCASE(cd.name)");

        return $query->rows;
    }

这种方式有效。在主页上,错误的分类菜单列表消失了(没有菜单了),在类别this one的分类列表页面左侧有正确的类别。

如果我删除&& $parent_id == 0部分,则会在页面上出错。

有人知道如何解决这个问题吗?任何帮助都会受到影响。如果您需要更多信息,我会给您。

-ps-抱歉我的英文不好

1 个答案:

答案 0 :(得分:0)

好的,经过大量的尝试后,我更好地搜索了OpenCart的论坛并发现了这个帖子: OpenCart Fora Thread

anser有如下: There's a "top" flag you set to make it show up as a top level menu

所以我做的是:

我已经编辑了新的主要类别(使用uid 355)并将其标记为顶部,但没有帮助,但我将其保留了下来。 然后,我编辑了主要类别的所有直接孩子,并将他们标记为顶部和foila,他们在那里。问题解决了。

因此,通过我对主核心的编辑以及类别的标记,问题现在已经解决了