Новости Joomla

👩‍💻 События плагинов и порядок их срабатывания при работе с пользовательскими полями Joomla и использовании FieldsHelper.

👩‍💻 События плагинов и порядок их срабатывания при работе с пользовательскими полями Joomla и использовании FieldsHelper.

В процессе работы с Joomla бывает необходимо работать с пользовательским интерфейсом более тонко, чем обычно. Все формы Joomla состоят из стандартных полей, содержанием, стилем отображения, состоянием (включено/выключено, доступно для редактирования или нет и т.д.) можно управлять с помощью плагинов. Да и для нестандартных проектов хорошей практикой является создание одного системного или нескольких плагинов групп "под проект", в которых храниться весь "нестандарт".

В этой статье описаны все триггеры, которые вызываются через Event Dispatcher из administrator/components/com_fields/src/Helper/FieldsHelper.php, с привязкой к жизненному циклу (порядку этапов работы запроса), аргументам, изменяемым данным и дальнейшему распространению по Joomla. Это поможет вам работать с Joomla свободнее и не опасаясь при этом потерять изменения при очередном обновлении движка.

Подходы, описанные в статье, полезны в тех случаях, когда вы работаете с данными в com_fields - механизме создания и редактирования пользовательских полей ядра Joomla и при использовании FieldsHelper. Многие сторонние компоненты не используют эту возможность, поэтому данная статья будет полезна лишь частично.

🏆 Открыто голосование за Joomla в премии CMS Critic People’s Choice Awards 2025

🏆 Открыто голосование за Joomla в  премии CMS Critic People’s Choice Awards 2025

🗓 Голосование продлится до 27 февраля 2026 года.

👩‍💻 Проголосовать! 👩‍💻

Номинации, в которых можно проголосовать за Joomla:
⭐️ Best Free CMS
⭐️ Best Open Source CMS
⭐️ Best Enterprise CMS

Также в номинации Best e-Commerce Solution участвуют компоненты интернет-магазинов для Joomla:
⭐️ HikaShop
⭐️ Virtuemart

В номинации Best Website Builder оказались:
⭐️ YooTheme
⭐️ SP Page Builder

Что такое CMS Critic Awards?
С 2012 года премия CMS Critic Awards занимает особое место в сообществе систем управления контентом (CMS). Это единственный в своем роде сайт, который составляет рейтинг системы управления контентом и связанных с ними решений на рынке — от малого до крупного и подчеркивает их инновации и услуги.

Каждый год награда CMS Critic Awards присуждается одному победителю в различных отраслевых категориях, таких как: «Лучшая облачная CMS», «Лучший DXP», «Лучшая Headless CMS и других. Затем результаты оглашаются через СМИ вместе с выбором редакции CMS Critic.
В этом году премия вернулась к своим традициям и только TOP-5 движков по количеству номинаций попали в 2-й этап - голосование.

@joomlafeed

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

evsmusic

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Всем привет! Пишу модуль поиска для вирта, чтобы при вводе артикула, мне выводиля искомый товар в внизу у него появлялись товары, которые являются дочерними от искомого товара. С этим разобрался. Мозг вспух, и что-то так и не могу догнать, как теперь сформировать запрос, чтобы при поиске дочернего товара так же внизу появлялся список родительского товара.

Итак, подробнее: в базе в таблице #__vm_product есть колонка под названием `product_parent_id`, в ней умолчанием забивается айди родительского товара. Тоесть есть товары с айдихами: 10,11,12,13,14,15, 10 - родительский, и его айди пишется в `product_parent_id` у дочерних товаров. Тоесть, 11,12,13 и тд имеют `product_parent_id = 10`, соответственно 10 - не имеет parent_id, точнее он просто НУЛЬ .
тут все просто, чтобы получить детей родителя - 10, надо тупо сделать так -
Код
SELECT `product_sku` FROM `#__virtuemart_product` WHERE product_parent_id =" . $result->virtuemart_product_id
- в $result собственно выбирается искомая айдиха товара связанная с его артикулом.

Теперь вопрос - что надо сформировать чтобы у детей показать остальных детей данного родителя и самого родителя.
*

evsmusic

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
В общем кому интересно, решил временно текущую проблема следующим, далеко не самым красивым образом, но пока работает:

Код

<?php

$db =& JFactory::getDBO();
//выбираем id родительского товара
$qurery1 = "SELECT product_parent_id
 FROM #__virtuemart_products
WHERE product_parent_id != 0
  AND virtuemart_product_id =".$result->virtuemart_product_id ."";
 
$db->setQuery($qurery1);

$childs_ch = $db->loadResultArray();

$parent_id = $childs_ch[0];

//если айдишка родительского товара отстутствует, тоесть в запрос пришел сам родитель, то надо вывести всего лишь детей
if(is_null($parent_id)){
$query2 = "SELECT product_sku FROM #__virtuemart_products
WHERE product_parent_id = ".$result->virtuemart_product_id ."";
 
$db->setQuery($query2, 0, $limit);
$childs = $db->loadObjectList();

}else{

//в ином случае выводим все что имеем: все дочение товары относительно папы текущего товара, самого папу, и себя
$query2 = "SELECT product_sku,virtuemart_product_id FROM #__virtuemart_products
  WHERE product_parent_id = ".$result->virtuemart_product_id ."
OR product_parent_id = ".$parent_id."        
OR virtuemart_product_id = ".$parent_id."
 ";
 
$db->setQuery($query2, 0, $limit);
$childs = $db->loadObjectList();
}

echo '<p><div style="display: inline-block;margin-top: 12px;">Из этой же категории: ';
echo '<span>';

if($childs){
foreach($childs as $key => $row){
$childlink = "index.php?option=com_virtuemart&view=productdetails&virtuemart_product_id=" .$row->virtuemart_product_id ."";
$chlink = htmlspecialchars(stripslashes($childlink));

?><a href="<?=$childlink?>"><?=$row->product_sku?></a> || <?php
#if($result->text){echo $result->text;}
}
}else{
echo 'Нет совпадений</p>';
}
echo '</span>';
echo '</div>';

?>


Минусы этой конструкции -
1: Не выводится краткое описание родителя к детям;
2: По желанию можно убрать вывод самого себя в дочерних товарах.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Исправить подтягивание значений контактов клиента из базы SQL

Автор Nessy74

Ответов: 5
Просмотров: 1120
Последний ответ 31.12.2015, 07:05:16
от Филипп Сорокин
Изменить запрос поиска mod_virtuemart_search

Автор Tokyo

Ответов: 1
Просмотров: 1545
Последний ответ 06.06.2013, 02:03:57
от fsv
Поиск по полям базы данных

Автор valensy

Ответов: 1
Просмотров: 1345
Последний ответ 08.09.2012, 21:39:45
от flyingspook
SQL запрос

Автор Infosakh

Ответов: 6
Просмотров: 2070
Последний ответ 29.05.2012, 21:06:09
от asimo
Отображение количества товаров в категориях. Требуется помощь по изменению не дефолтового модуля кат

Автор mmontana

Ответов: 0
Просмотров: 1249
Последний ответ 22.01.2010, 02:13:55
от mmontana