Новости Joomla

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

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

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

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

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

Читать статью на Хабре.

@joomlafeed

🏆 Открыто голосование за 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 Ответов
  • 3169 Просмотров
*

dmitrij

  • Новичок
  • 9
  • 0 / 0
поиск
« : 30.07.2007, 13:48:09 »
Добрый день, у меня один и тот же товар находиться в 3 разных категориях и при поиске на сайте возникает проблема: выводит этот же товар со всех 3 категорий хотя он один и тот же, подскажите плиз как подправить поисковой мамбот виртуал марта что бы когда выводился товар то только выводился один товар, а не со всех категорий один и тотже.
*

dmitrij

  • Новичок
  • 9
  • 0 / 0
Re: поиск
« Ответ #1 : 02.08.2007, 11:25:24 »
Вот код поискового мамбота, теперь может будет проще подсказать.

<?php
defined( '_VALID_MOS' ) or die( 'Прямой доступ запрещен.' );
$_MAMBOTS->registerFunction( 'onSearch', 'botSearchVM' );

function botSearchVM( $text, $phrase='', $ordering='' ) {
  global $database;
  $text = trim( $text );
  if ($text == '') {
    return array();
  }
   $wheres = array();
   switch ($phrase) {
      case 'exact':
         $wheres2 = array();
         $wheres2[] = "LOWER(product_name) LIKE '%$text%'";
         $wheres2[] = "LOWER(product_sku) LIKE '%$text%'";
         $wheres2[] = "LOWER(product_desc) LIKE '%$text%'";
         $wheres2[] = "LOWER(product_s_desc) LIKE '%$text%'";
         $wheres2[] = "LOWER(product_url) LIKE '%$text%'";
         $where = '(' . implode( ') OR (', $wheres2 ) . ')';
         break;
      case 'all':
      case 'any':
      default:
         $words = explode( ' ', $text );
         $wheres = array();
         foreach ($words as $word) {
            $wheres2 = array();
            $wheres2[] = "LOWER(product_name) LIKE '%$text%'";
            $wheres2[] = "LOWER(product_sku) LIKE '%$text%'";
            $wheres2[] = "LOWER(product_desc) LIKE '%$text%'";
            $wheres2[] = "LOWER(product_s_desc) LIKE '%$text%'";
            $wheres2[] = "LOWER(product_url) LIKE '%$text%'";
            $wheres[] = implode( ' OR ', $wheres2 );
         }
         $where = '(' . implode( ($phrase == 'all' ? ') AND (' : ') OR ('), $wheres ) . ')';
         break;
   }

   switch ($ordering) {
      case 'newest':
      default:
         $order = '#__vm_product.cdate DESC';
         break;
      case 'oldest':
         $order = '#__vm_product.cdate ASC';
         break;
      case 'popular':
         $order = '#__vm_product.product_name ASC';
         break;
      case 'alpha':
         $order = '#__vm_product.product_name ASC';
         break;
      case 'category':
         $order = '#__vm_category.category_name ASC';
         break;
   }
   
 
  $database->setQuery( " SELECT id, name FROM  `#__menu` WHERE link LIKE '%com_virtuemart%' AND published=1 AND access=0");
  $database->loadObject( $Item );
  $ItemName = !empty( $Item->name ) ? $Item->name : "Shop";
  $Itemid = !empty( $Item->id ) ? $Item->id : "1";

  $query = "SELECT product_name as title,"
               . "\n    FROM_UNIXTIME( #__vm_product.cdate, '%Y-%m-%d %H:%i:%s'  ) AS created,"
               . "\n    product_s_desc AS text,"
               . "\n    CONCAT('$ItemName/',#__vm_category.category_name) as section,"
               
               . "\n    CONCAT('index.php?option=com_virtuemart&page=shop.product_details&flypage=',#__vm_category.category_flypage,'&category_id=',#__vm_category.category_id,'&product_id=', #__vm_product.product_id, '&Itemid=".$Itemid."' ) as href,"
               . "\n    '2' as browsernav"
               . "\n FROM #__vm_product"
               . "\n LEFT JOIN `#__vm_product_category_xref` ON `#__vm_product_category_xref`.`product_id` = `#__vm_product`.`product_id`"
               . "\n LEFT JOIN `#__vm_category` ON `#__vm_product_category_xref`.`category_id` = `#__vm_category`.`category_id`"

               . "\n WHERE $where"
            . "\n AND (product_parent_id='' OR product_parent_id='0')"
            . "\n AND product_publish='y'"
               . "\n ORDER BY $order" ;
               
  $database->setQuery( $query );

  $row = $database->loadObjectList();
 
  return $row;
}

?>
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Поиск по ключевым словам?

Автор Archorosho

Ответов: 2
Просмотров: 4369
Последний ответ 14.02.2011, 19:49:46
от Артеист
Как добавить корзину, список последних товаров, поиск товаров на первую страницу joomla?

Автор X3MAL

Ответов: 2
Просмотров: 3714
Последний ответ 24.12.2010, 22:30:13
от terr
Virtuemart+joomfish поиск по другим языкам

Автор Egor_admin2003

Ответов: 3
Просмотров: 3856
Последний ответ 09.06.2010, 14:13:26
от Vladzimir
поиск по цене

Автор Bickaze

Ответов: 3
Просмотров: 3529
Последний ответ 01.12.2008, 20:08:01
от Bickaze
Поиск по цене товара ( от и до )

Автор rubik

Ответов: 2
Просмотров: 3193
Последний ответ 30.05.2008, 13:25:15
от Xpom