Новости 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 Гость просматривают эту тему.
  • 2 Ответов
  • 1626 Просмотров
*

mondee

  • Осваиваюсь на форуме
  • 15
  • 1 / 0
Формирую таблицу таким кодом:
Код

$tableheader[] = '<center><a class="nohref" title="'.$VM_LANG->_('CLUB_NUM').'">'.$VM_LANG->_('CLUB_KRAT_NUM').'</center>';
// ... тут несколько строк пропущено
$tableheader[] = '<center><a class="nohref" title="'.$VM_LANG->_('CLUB_O').'">'.$VM_LANG->_('CLUB_KRAT_O').'</center>';

$table =& new HTML_Table('width="100%"');

$table->addRow( $tableheader, 'class="sectiontableentry5"', 'td', true );

foreach( $products as $product ) {

foreach( $product as $attr => $val ) {
// Using this we make all the variables available in the template
// translated example: $this->set( 'product_name', $product_name );
$this->set( $attr, $val );
}

$data[$row][] = '<center>'.$product['club_num'].'</center>';
// ... тут несколько строк пропущено
$data[$row][] = '<center>'.$product['club_o'].'</center>';

$row++;
 
}
$i=1;
foreach($data as $key => $value) {

$table->addRow( $data[$key], 'class="sectiontableentry'.$i.'"', 'td', true );
$i = $i == 1 ? 2 : 1;
}

echo $table->toHtml();


Соответственно заголовок таблицы имеет класс "sectiontableentry5", а каждая строка в таблице чередует "sectiontableentry1" и "sectiontableentry2"

В базе данных имею поле club_div, в котором есть значения двух видов "Z" и "V"
Сейчас задался идеей, чтобы каждая строка имела свой класс в зависимости от значения поля club_div, т.е. "sectiontableentry1" если club_div=Z и "sectiontableentry2" если club_div=V
Что мне поменять в коде, чтобы это получилось?
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Код: php
if ($club_div == Z) {
$class = 'sectiontableentry1';
} else {
$class = 'sectiontableentry2';
}
и подставлять куда нужно
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

mondee

  • Осваиваюсь на форуме
  • 15
  • 1 / 0
Я примерно так и делал, вот что у меня получалось:
Код
$tableheader[] = '<center><a class="nohref" title="'.$VM_LANG->_('CLUB_NUM').'">'.$VM_LANG->_('CLUB_KRAT_NUM').'</center>';
// ... тут несколько строк пропущено
$tableheader[] = '<center><a class="nohref" title="'.$VM_LANG->_('CLUB_O').'">'.$VM_LANG->_('CLUB_KRAT_O').'</center>';

$table =& new HTML_Table('width="100%"');

$table->addRow( $tableheader, 'class="sectiontableentry5"', 'td', true );

foreach( $products as $product ) {

foreach( $product as $attr => $val ) {
// Using this we make all the variables available in the template
// translated example: $this->set( 'product_name', $product_name );
$this->set( $attr, $val );
}

$data[$row][] = '<center>'.$product['club_num'].'</center>';
// ... тут несколько строк пропущено
$data[$row][] = '<center>'.$product['club_o'].'</center>';

$row++;
   if ($product['club_div'] == Z ) {
           $class = 'sectiontableentry1';
           } else {
           $class = 'sectiontableentry2';
        }
}

foreach($data as $key => $value) {

$table->addRow( $data[$key], 'class="'.$class.'"', 'td', true );

}

echo $table->toHtml();

но в таком случае $class принимает значение последнего цикла выборки товара, и соответственно все строки имеют один класс :(

Может я не туда засовываю этот if?

Я думаю надо массив какой-то $class мутить чтоб для каждой $data[$key] была своя $class. Только как это сделать?
« Последнее редактирование: 10.09.2011, 08:52:32 от mondee »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Ошибка #1050 при переносе базы данных на хостинг

Автор Ksen

Ответов: 7
Просмотров: 26824
Последний ответ 16.03.2020, 17:47:29
от Petrovich
Передача данных в форму при нажатии на ссылку

Автор usmdamir

Ответов: 4
Просмотров: 2615
Последний ответ 26.07.2017, 09:40:22
от usmdamir
Re: Изменение таблиц базы данных

Автор ZAlex60

Ответов: 4
Просмотров: 1926
Последний ответ 23.09.2016, 09:57:14
от ZAlex60
Ввод данных на сайте – подстановка их в текст. документ

Автор Plazmodina

Ответов: 4
Просмотров: 3155
Последний ответ 10.09.2015, 15:20:44
от DeKajper
[Решено] Права администратора или создание нового администратора через базу данных

Автор Savior

Ответов: 8
Просмотров: 7934
Последний ответ 24.10.2014, 20:01:45
от AlekVolsk