Новости Joomla

Вышли релизы безопасности Joomla 5.3.4 и Joomla 4.4.14

Релиз безопасности Joomla 5.3.4

Проект Joomla спешит сообщить о выпуске Joomla 5.3.4 и Joomla 4.4.14. Это релиз безопасности для серии Joomla 5.3 и релиз безопасности для серии Joomla 4.4.

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

nastjushka

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

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

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

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

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

fsv

  • Moderator
  • 2781
  • 411 / 2
В переопределенном шаблоне карточки товара:
Код: php
$cat = VmModel::getModel('category');
$parent = $cat->getParentCategory((int)$this->product->virtuemart_category_id);
if( $parent->category_name ){
    echo $parent->category_name;
}
Веб-разработка: заказ. Только новая разработка.
*

nastjushka

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


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

fsv

  • Moderator
  • 2781
  • 411 / 2
Спасибо, так он у меня начал выводить категорию "Марка авто", а как прописать, чтобы выводил  "Тип детали"?
попробуйте
Код: 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 запрос в базу.
Веб-разработка: заказ. Только новая разработка.
*

nastjushka

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

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

nastjushka

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