0 Пользователей и 1 Гость просматривают эту тему.
  • 5 Ответов
  • 738 Просмотров
*

nastjushka

  • Осваиваюсь на форуме
  • 48
  • 6
У меня есть сложный каталог типа:

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

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

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

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

fsv

  • Moderator
  • 2525
  • 367
В переопределенном шаблоне карточки товара:
Код: php
$cat = VmModel::getModel('category');
$parent = $cat->getParentCategory((int)$this->product->virtuemart_category_id);
if( $parent->category_name ){
    echo $parent->category_name;
}
Заказать разработку:    расширения Joomla  |   интерфейсы на javascript(jQuery)  |  мобильные приложения
*

nastjushka

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


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

fsv

  • Moderator
  • 2525
  • 367
Спасибо, так он у меня начал выводить категорию "Марка авто", а как прописать, чтобы выводил  "Тип детали"?
попробуйте
Код: 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;
}
}
не проверял

Только вот есть некоторые сомнения... Включите отладку и посмотрите, сколько запросов генерирует эта борода. Возможно, будет лучше не использовать API VM, а написать 1 запрос в базу.
Заказать разработку:    расширения Joomla  |   интерфейсы на javascript(jQuery)  |  мобильные приложения
*

nastjushka

  • Осваиваюсь на форуме
  • 48
  • 6
Работает, если есть три уровня вложенности, но если вдруг встречается два уровня или один - ничего не выводит...

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

nastjushka

  • Осваиваюсь на форуме
  • 48
  • 6
Дописала так:
Код
<?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, 12:52:07 от nastjushka »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Краткое описание категории

Автор SkaterSPB

Ответов: 5
Просмотров: 883
Последний ответ 23.07.2017, 03:04:34
от Masha0701
Фильтр наличия товара

Автор Servelatin

Ответов: 10
Просмотров: 1179
Последний ответ 14.07.2017, 11:09:44
от OutLaw1
Вывод описания категории товаров модуле VirtueMart Товары

Автор Marcello

Ответов: 1
Просмотров: 97
Последний ответ 09.07.2017, 14:08:26
от Marcello
Вывод производителей ссылкой в карточке товара

Автор One

Ответов: 1
Просмотров: 90
Последний ответ 29.05.2017, 15:46:12
от gartes
Как вывести alt для изображения в карточке?

Автор Anna01

Ответов: 1
Просмотров: 164
Последний ответ 29.04.2017, 22:19:25
от gartes