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

busik

  • Захожу иногда
  • 186
  • 7 / 0
Никак не могу вывести три модуля в одну строку внизу сайта (так, чтобы были посередине и равной ширины). Перепробовал все варианты.

Сейчас стоит код

<div id="bottomwide">
      <div id="bottom" class="clearfix">
         <div class="pos14"><jdoc:include type="modules" name="position-14" style="xhtml" /></div>
         <div class="pos15"><jdoc:include type="modules" name="position-15" style="xhtml" /></div>
         <div class="pos16"><jdoc:include type="modules" name="position-16" style="xhtml" /></div>
      </div>
</div>

Для них в CSS прописано следующее

#bottomwide {width:100%; margin: auto; position: relative; background-color:#333;}
#bottom {max-width:980px; margin: auto; height:100%; padding-bottom:10px;  position: relative; background: none;}
#bottom:before,#bottom:after {content:"";display:table;}
.pos14  h3, .pos15  h3, .pos16  h3 {color:#fff; font-weight:bold; font-family: 'tahoma', sans-serif; font-size:16px; margin:0px; text-shadow:none;}
.pos14, .pos15, .pos16 { background:none; color:#fff; border:0; border-radius:5px; float: left; padding-left: 3%;width: 30%; text-shadow: 0 1px #555;}

И что не делаю, что не перепробовал, три модуля все равно встают друг под другом. Как правильно прописать, чтобы они встали в строку?
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
.pos14, .pos15, .pos16 {float:left;}
*

busik

  • Захожу иногда
  • 186
  • 7 / 0
.pos14, .pos15, .pos16 {float:left;}

Чего-то не помогло
*

Ilhom666

  • Завсегдатай
  • 1384
  • 184 / 0
*

busik

  • Захожу иногда
  • 186
  • 7 / 0
Забыл уточнить - модули нужны для вывода в футере
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
да без разницы, где
не помогло - смотреть конкретно уже надо, ссылку
*

darkghost

  • Живу я здесь
  • 2212
  • 97 / 0
Цитировать
... padding-left: 3%;width: 30%;
Если сложить и умножить на *3, то получится 99, в принципе должно работать. Вот только не вижу отступы между .pos14, .pos15, .pos16 . Без ссылки никак не разобраться 
*

busik

  • Захожу иногда
  • 186
  • 7 / 0
Ну вот перепрописал все заново, и все равно модули стоят друг под другом, а не в строку. Вроде бы все правильно, уже и не знаю что и думать

вот код

<?php if($this->countModules('bottom1 or bottom2 or bottom3')) : ?>
   <div id="bottom123">
      <?php if($this->countModules('bottom1')) : ?>
         <div id="bottom1">
              <jdoc:include type="modules" name="bottom1" style="xhtml" />
         </div>
      <?php endif; ?>         
      <?php if($this->countModules('bottom2')) : ?>
         <div id="bottom2">
              <jdoc:include type="modules" name="bottom2" style="xhtml" />
         </div>
      <?php endif; ?>         
      <?php if($this->countModules('bottom3')) : ?>
         <div id="bottom3">
              <jdoc:include type="modules" name="bottom3" style="xhtml" />
         </div>
      <?php endif; ?>         
   </div>               
<?php endif; ?>   

Вот CSS

#bottom123 {
   width: 100%;
   display: inline-block;
   margin: 15px 0;
   padding: 0;
   height: auto;
}

#bottom1, #bottom2, #bottom3,
{
   float:left;
   width: 31.2%;
   margin: 0 1%;
   padding: 0;
}

Ну что же тут не так? :(

*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
#bottom123 {
   width: 100%;
   display: inline-block;
   margin: 15px 0;
   padding: 0;
   height: auto;
}

#bottom1, #bottom2, #bottom3,
{
   float:left;
   width: 31.2%;
   margin: 0 1%;
   padding: 0;
}
выделенное - лишнее.
сайт смотреть надо, чтобы дать более точный ответ
*

busik

  • Захожу иногда
  • 186
  • 7 / 0
#bottom123 {
   width: 100%;
   display: inline-block;
   margin: 15px 0;
   padding: 0;
   height: auto;
}

#bottom1, #bottom2, #bottom3,
{
   float:left;
   width: 31.2%;
   margin: 0 1%;
   padding: 0;
}
выделенное - лишнее.
сайт смотреть надо, чтобы дать более точный ответ

Попробовал - что то не вышло
*

midav

  • Давно я тут
  • 926
  • 115 / 1
И первый и второй вариант кода работают . Во втором просто надо убрать запятую после #bottom3 . И свойство inline-block , хотя и с ним будет работать .
ссылка
Ответы на вопросы по CSS . Откройте для себя Firebug
*

busik

  • Захожу иногда
  • 186
  • 7 / 0
Спасибо. Отвлекся на ловлю вирусов. Буду пробовать.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вывести дочерние товары в самой карточке родительского товар VirtueMart

Автор aliallaxverdiev91

Ответов: 2
Просмотров: 3075
Последний ответ 03.03.2024, 11:32:49
от gtiosx
Как вывести Alt картинки в описание Lightbox?

Автор art22

Ответов: 2
Просмотров: 3050
Последний ответ 14.05.2023, 09:21:39
от sivers
Съезжают модули на странице материала

Автор sibdes

Ответов: 3
Просмотров: 3725
Последний ответ 24.04.2023, 12:50:21
от beliyadm
Через модуль html надо вставить три изображения в одну линию (горизонтально)

Автор dionisimuss

Ответов: 10
Просмотров: 1940
Последний ответ 21.12.2022, 20:59:52
от dionisimuss
Переопределенные модули подтягиваются из другого шаблона

Автор Vlad1

Ответов: 3
Просмотров: 1011
Последний ответ 11.11.2021, 21:57:51
от Vlad1