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-抱歉我的英文不好
答案 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,他们在那里。问题解决了。
因此,通过我对主核心的编辑以及类别的标记,问题现在已经解决了