Форум русской поддержки Joomla!® CMS
04.12.2016, 10:13:08 *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

Войти
   
   Начало   Поиск Joomla 3.0 FAQ Joomla 2.5 FAQ Joomla 1.5 FAQ Правила форума Новости Joomla Реклама Войти Регистрация Помощь  
Страниц: [1]   Вниз
  Добавить закладку  |  Печать  
Автор

Вывод в карточке товара название родительской категории

 (Прочитано 487 раз)
0 Пользователей и 1 Гость смотрят эту тему.
nastjushka
Осваиваюсь на форуме
***

Репутация: +5/-0
Offline Offline

Пол: Женский
Сообщений: 46



« : 16.07.2015, 14:06:08 »

У меня есть сложный каталог типа:

Тип детали
- Марка авто
-- Модель авто

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

Мне в карточке товара нужно указать "Тип детали", т.е. родительскую категорию товара, как это сделать?

Подскажите пожалуйста.
Записан
fsv
Moderator
*****

Репутация: +330/-2
Offline Offline

Пол: Мужской
Сообщений: 2235


« Ответ #1 : 18.07.2015, 01:15:26 »

В переопределенном шаблоне карточки товара:
Код
$cat = VmModel::getModel('category');
$parent = $cat->getParentCategory((int)$this->product->virtuemart_category_id);
if( $parent->category_name ){
   echo $parent->category_name;
}
Записан
nastjushka
Осваиваюсь на форуме
***

Репутация: +5/-0
Offline Offline

Пол: Женский
Сообщений: 46



« Ответ #2 : 20.07.2015, 12:09:28 »

В переопределенном шаблоне карточки товара:
Код
$cat = VmModel::getModel('category');
$parent = $cat->getParentCategory((int)$this->product->virtuemart_category_id);
if( $parent->category_name ){
   echo $parent->category_name;
}


Спасибо, так он у меня начал выводить категорию "Марка авто", а как прописать, чтобы выводил  "Тип детали"?
Записан
fsv
Moderator
*****

Репутация: +330/-2
Offline Offline

Пол: Мужской
Сообщений: 2235


« Ответ #3 : 20.07.2015, 12:49:23 »

Спасибо, так он у меня начал выводить категорию "Марка авто", а как прописать, чтобы выводил  "Тип детали"?
попробуйте
Код
$cat = VmModel::getModel('category');
$parent = $cat->getParentCategory((int)$this->product->virtuemart_category_id);
if( $parent->virtuemart_category_id ){
$grandparent = $cat->getParentCategory((int)$parent->virtuemart_category_id);
if( $grandparent->category_name ){
echo $grandparent->category_name;
}
}
не проверял

Только вот есть некоторые сомнения... Включите отладку и посмотрите, сколько запросов генерирует эта борода. Возможно, будет лучше не использовать API VM, а написать 1 запрос в базу.
Записан
nastjushka
Осваиваюсь на форуме
***

Репутация: +5/-0
Offline Offline

Пол: Женский
Сообщений: 46



« Ответ #4 : 20.07.2015, 13:44:01 »

Работает, если есть три уровня вложенности, но если вдруг встречается два уровня или один - ничего не выводит...

Включила отладку, и 9347 SQL-запросов зафиксировано, но это по всей странице http://avtoimperial.by/catalogue, а как узнать отдельно по этому коду?
Записан
nastjushka
Осваиваюсь на форуме
***

Репутация: +5/-0
Offline Offline

Пол: Женский
Сообщений: 46



« Ответ #5 : 20.07.2015, 13:47:36 »

Дописала так:
Код:
<?php
$cat = VmModel::getModel('category');
$parent = $cat->getParentCategory((int)$this->product->virtuemart_category_id);
if( $parent->virtuemart_category_id ){
$grandparent = $cat->getParentCategory((int)$parent->virtuemart_category_id);
if( $grandparent->category_name ){
echo $grandparent->category_name;
}else{
echo $parent->category_name;}
} else {
echo $product->category_name;}
?>
 

Стал выводить все, как нужно)

Нужно ли заморачиваться с запросами к базе? ведь 9 тыс - это много? а если напрямую к базе делать запрос, то это как?

« Последнее редактирование: 20.07.2015, 13:52:07 от nastjushka » Записан
Страниц: [1]   Вверх
  Добавить закладку  |  Печать  
 
Перейти в:  

Powered by SMF 1.1.21 | SMF © 2006, Simple Machines

Joomlaforum.ru is not affiliated with or endorsed by the Joomla! Project or Open Source Matters.
The Joomla! name and logo is used under a limited license granted by Open Source Matters
the trademark holder in the United States and other countries.

LiveInternet