Новости Joomla

Свои типы полей в Joomla.Это большая тема, о которой можно говорить очень много

Свои типы полей в Joomla.Это большая тема, о которой можно говорить очень много

👩‍💻 Свои типы полей в Joomla.Это большая тема, о которой можно говорить очень много. Самое главное, что возможности применения ограничиваются только вашей больной фантазией. Вы строите интерфейс своего модуля или плагина и вам нужно подтянуть данные из сторонней системы (список чего-нибудь по какому-нибудь API), чтобы сохранить выбранный id в Joomla. Или сделать какую-то проверку и в зависимости от неё показать то или иное сообщение пользователю. Для этого подойдут свои пользовательские типы полей. Интерфейс Joomla по большей части описан в XML-файлах. У каждого из них свои параметры. Некоторые не описаны в документации (manual.joomla.org), поэтому самым любопытным будет полезно заглянуть в собственно файлы фреймворка по пути

libraries/src/Form/FormField.php, а так же в
libraries/src/Form/Fields. У каждого класса поля перечислены его специфические свойства, которые можно описывать в XML. А в своём типе поля вы можете устанавливать эти значения программно. В моём модуле WT Quick links под капотом происходят изменения. Теперь для работы (в админке) ему нужен вспомогательный плагин. А в самом модуле нам бы проверить, а не выключен ли он? В Joomla есть тип поля Note - заметка. Его можно использовать для вывода примечаний.

<field type="note"     name="your_note_for_user"     label="Заголовок примечания"     title="Альтернативный способ для заголовка"     description="Текст примечания"     class="col-12 alert alert-info"     heading="h1"     close="true"/>
heading - указывать уровень заголовка.
close - позволяет закрыть это примечание. В классе поля
libraries/src/Form/Field/NoteField.php описана логика вывода. И в принципе оно нам подходит для нашей задачи. Но оно будет выводить сообщение всегда, а нам нужно только тогда, когда плагин отключён.Поэтому берём и создаём свой класс поля, который мы унаследуем от
NoteField. Это значит, что у нас в руках будет весь инструментарий стандартного поля
Note + то, что мы сами добавим. В XML-манифест добавляем наше поле
<field type="systempluginstatus"      name="systempluginstatus"     addfieldprefix="Joomla\Module\Wtquicklinks\Site\Fields"/>
-
type - имя файла и класса,-
addfieldprefix - указываем namespace к нашему классу, может быть любой нам нужный-
name - нельзя полю без имени...Это означает, что Joomla будет использовать класс поля из файла
modules/mod_wt_quick_links/src/Fields/SystempluginstatusField.php.А в классе поля будет написано следующее:
<?php// namespace для атрибута addfieldprefixnamespace Joomla\Module\Wtquicklinks\Site\Fields;// нельзя напрямую обращаться к этому файлуdefined('_JEXEC') or die;// подключаем родительский класс для переопределенияuse Joomla\CMS\Form\Field\NoteField;use Joomla\CMS\Language\Text;use Joomla\CMS\Plugin\PluginHelper;// имя класса и имя файла точь-в-точьclass SystempluginstatusField extends NoteField{     protected $type = 'Systempluginstatus';     protected function getLabel()          {               // если плагин не включён               if(PluginHelper::isEnabled('system','wtquicklinks')) {                    // меняем свойства родительского класса                    $this->class = 'alert alert-danger w-100';                    $this->element['label'] = '⚠️ А-а-а-а!';                    $this->element['description'] = 'Плагин не включён!!';                    // и просто рендерим его с нашими свойствами                    return parent::getLabel();               }          // А иначе всё хорошо, скрываем поле из виду.          $this->parentclass = 'd-none';          return '';     }}
Просто и удобно. И людям приятно, что о них позаботились и рассказали почему что-то не работает.@webtolkru#joomla #php #webdev #разработка

Обновлена информация в Плане развития Joomla

👩‍💻 Обновлена информация в Плане развития Joomla.Здесь собрана информация о датах релизов, описаны принципы версионирования, указаны ответственные за релизы, а так же даты окончания поддержки релизов. Опираясь на эту информацию вы можете планировать развитие ваших интернет-проектов.👩‍💻 Что нового?⛔️ Joomla 4.Дата окончания исправления ошибок безопасности в версии 4.x - 14 октября 2025г. ⚠️ После этой даты Joomla 4 прекратит получать какие-либо обновления, в том числе безопасности - вообще. Рекомендуем обновить ваши сайты до актуальной Joomla 5.✅ Joomla 5.- Дата окончания исправления ошибок в версии 5.x - 13 октября 2026г.- Дата окончания исправления ошибок безопасности в версии 5.x - 12 октября 2027 года.- Текущая актуальная (на момент написания заметки) версия - 5.3.1.- Опубликовано расписание выхода релизов Joomla 5.4. Стабильный релиз ожидается 14 октября 2025 года.✅ Joomla 6.- Дата окончания исправления ошибок в версии 6.x - 17 октября 2028г.- Дата окончания исправления ошибок безопасности в версии 6.x - 16 октября 2029г.- Опубликовано расписание выхода релизов Joomla 6.0. Стабильный релиз ожидается 14 октября 2025 года.- Для разработчиков уже доступна Joomla 6.0.0-alpha1.✅ Joomla! Framework.Обновлена информация о Joomla! Framework - полноценном PHP-фреймворке для разработки. Он в версиях 1.х и 2.х был самостоятельным параллельным проектом, однако начиная с версии Joomla 4.0 стал её основой. Добавлена информация о Joomla! Framework 3.x, который вышел 6 октября 2023 года. Его можно использовать в тех случаях, когда вам в проекте не нужна CMS Joomla целиком.Подробнее на сайте Joomla-сообщества Joomlaportal.ru#joomla #community

Компания JetBrains рассказала о своей поддержке Joomla

Компания JetBrains рассказала о своей поддержке Joomla

JetBrains - один из мировых лидеров в разработке программного обеспечения для разработчиков. Её программные продукты - это IDE - профессиональные среды разработки, которые отличаются от простого блокнота/редактора с плагинами набором всевозможных инструментов для разработчиков, глубоким анализом кодовой базы, подсказками по ней и по языку программирования, отладкой ошибок и многим-многим другим. Одним из самых известных продуктов компании является IDE PHP Storm, который можно назвать отраслевым стандартом PHP-разработчика.

В статье How PhpStorm Helps Maintain PHP Open-Source Projects: Interviews and Real-World Examples в блоге компании описываются Open Source проекты, которым JetBrains оказывает поддержку (это могут быть бесплатные лицензии для разработчиков для некоммерческих проектов).

В список попали:

  • PHPUnit - фреймворк для unit-тестирования в PHP
  • Doctrine DBAL - библиотека для PHP, которая предоставляет лёгкий и гибкий слой для коммуникации с базой данных. Она поддерживает различные базы данных через единый и согласованный API.
  • CodeIgniter — популярный MVC-фреймворк для разработки на PHP
  • Joomla! - наша любимая CMS.

Эти названия (кроме "Joomla") чаще всего не слышат вебмастера и разработчики обычных сайтов и интернет-магазинов. Но эти названия хорошо знакомы PHP-разработчикам, которые создают сложные и высоконагруженные проекты и микросервисы. То, что Joomla оказалась в одном ряду с такими программными инструментами - делает ей честь.

🙏 За ссылку спасибо участнику нашего сообщества Ринату Кажетову (@rkazhet).

Подпишитесь на @joomlafeed

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

Levhik

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Выподающее меню
« : 23.08.2010, 21:56:30 »
подскажите пожалуйста новичку как можно сделать такое меню как на скрине ниже?

*

iluho

  • Давно я тут
  • 605
  • 50 / 4
  • Гламурный КабанчеГ
Re: Выподающее меню
« Ответ #1 : 23.08.2010, 22:07:35 »
это так называемые "табы". попробуйте копать по названию. по английски tabs модулей много таких
Милый и порядочный! Верьте мне во всем!
*

iluho

  • Давно я тут
  • 605
  • 50 / 4
  • Гламурный КабанчеГ
Re: Выподающее меню
« Ответ #2 : 23.08.2010, 22:08:51 »
http://extensions.joomla.org/search?q=tab

посмотрите, может что понравится
Милый и порядочный! Верьте мне во всем!
*

danik.html

  • Живу я здесь
  • 2650
  • 353 / 4
Re: Выподающее меню
« Ответ #3 : 23.08.2010, 22:09:59 »
если без полупрозрачной рамки покругу и ссылки Портал телефонов, MP3 ... то на чистом css(и пинками для ие) и стандартным модулем mod_mainmenu. Новичек врядли осилит.
【Мегапак Virtuemart:
 • метатеги (description,keywords)
 • заголовки (title)
 • красивые алиасы (чпу) без тормозов и дублей!
*

Levhik

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Re: Выподающее меню
« Ответ #4 : 23.08.2010, 22:23:29 »
если без полупрозрачной рамки покругу и ссылки Портал телефонов, MP3 ... то на чистом css(и пинками для ие) и стандартным модулем mod_mainmenu. Новичек врядли осилит.

я осилю. просто скажите через списки <ul> это реально сделать? Там надо что бы список 1-го уровня был одной ширины(110px) тогда все остальные подменю тоже такой ширины стают. А мне надо телефоны, mp3, фото, GPS... имели один backgraund. А осталные - беленький фон с ободочком как и там.
*

danik.html

  • Живу я здесь
  • 2650
  • 353 / 4
Re: Выподающее меню
« Ответ #5 : 23.08.2010, 22:48:03 »
на ul можно сделать, но либо без полупрозрачной каемки(можно просто зеленый бордюр) либо с ней, но фиксированной ширины.
ul.menu > li{
    float: left;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    background: #fff;
    border: 3px solid #0f0;
    border-bottom: none;
}
ul.menu > li > ul{
   display: none;
   overflow: hidden;
    border-top-right-radius: 10px;
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
    background: #fff;
    border: 3px solid #0f0;
}
ul.menu > li:hover > ul{
    display: block;
}
ul.menu > li > ul > li{
    float: left;
}

вот css-набросок. border-radius нужно продублировать для -moz- и -webkit- и border-radius.htc  . если в планах есть ие6( менее 7 % юзеров по liveinternet статистике) то нужен еще iehover.htc
【Мегапак Virtuemart:
 • метатеги (description,keywords)
 • заголовки (title)
 • красивые алиасы (чпу) без тормозов и дублей!
*

Levhik

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Re: Выподающее меню
« Ответ #6 : 24.08.2010, 01:47:16 »
в общем вот что у меня получилось. При наведении мышки на меню появляется такое серенькое меню:



вот код:
Код
<!DOCTYPE HTML PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ru-ru" lang="ru-ru" dir="ltr" >
<head>

<style type="text/css">
#top-menu ul{
list-style: none;
}

#top-menu > ul > li{
float: left;
}

#top-menu ul.menu-nav > li{
overflow:visible;
width: 110px;
}

#top-menu ul.menu-nav > li > a{
background-color:blue;
color:white;
display:block;
height:40px;
}

#top-menu ul.menu-nav > li > ul {
width: 350px;
display:none;
}

#top-menu ul.menu-nav > li:hover > ul {display:block}

#top-menu ul.menu-nav > li > ul > li {
background-color: silver;
width: 150px;
float: left;
}

#top-menu ul.menu-nav > li > ul > li  > a{
font-style: italic;
padding-left: 5px;
}

#top-menu ul.menu-nav > li > ul > li  > ul{
clear: both;
}

#top-menu ul.menu-nav > li > ul > li  > ul > li > a{
padding-left: 10px;
display: block;
margin: 3px 0;
}
</style>

</head>
<body>

<div id="top-menu">
<ul class="menu-nav">
<li class="parent item28">
<a href="#"><span>Протеиновые коктейли</span></a>

<ul>
<li class="parent item55">
<a href="#"><span>по категориям</span></a>
<ul>
<li class="item56">
<a href="#"><span>сывороточный протеин</span></a>
</li>

<li class="item57">

<a href="#"><span>казеин</span></a>
</li>

<li class="item58">
<a href="#"><span>яичный</span></a>
</li>
</ul>
</li>

<li class="parent item59">

<a href="#"><span>по брендам</span></a>
<ul>
<li class="item60">
<a href="#"><span>OLIMP</span></a>
</li>

<li class="item61">
<a href="#"><span>MAMUT</span></a>

</li>

<li class="item62">
<a href="#"><span>NATURAL</span></a>
</li>
</ul>
</li>
</ul>
</li>


<li class="item29">
<a href="#"><span>Возможности</span></a>
</li>

<li class="item18">
<a href="#"><span>Новости</span></a>
</li>

<li class="item30">
<a href="#"><span>Сообщество</span></a>

</li>
</ul>
</div>
</body>
</html>

все работает как надо, вот только не нравится как серый бэкграунд тображается. хотелось чтобы было так:



как вариант можно поставить путой блок с со стилем clear: both; но я не знаю как это в Joomla можно сделать.
*

danik.html

  • Живу я здесь
  • 2650
  • 353 / 4
Re: Выподающее меню
« Ответ #7 : 24.08.2010, 12:01:44 »
#top-menu ul.menu-nav > li > ul {
   width: 350px;
   display:none;
   background-color: silver;
   overflow: hidden;

}

для ие6 еще нужно zoom: 1;
благодаря overflow: hidden (zoom: 1) блок будет охватывать все плавающие дочерние элементы.
【Мегапак Virtuemart:
 • метатеги (description,keywords)
 • заголовки (title)
 • красивые алиасы (чпу) без тормозов и дублей!
*

Levhik

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Re: Выподающее меню
« Ответ #8 : 24.08.2010, 20:33:12 »
усе работает. осталось хаки прописать. начиная с ie6.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

убрать из меню заголовки h3

Автор nexter

Ответов: 19
Просмотров: 7879
Последний ответ 03.02.2020, 18:49:47
от durte
При добавлении нового пункта меню не отображается содержимое

Автор Denko

Ответов: 2
Просмотров: 3290
Последний ответ 16.01.2020, 18:40:55
от Denko
Не нажимается пункт меню на мобильной версии

Автор Sensession

Ответов: 7
Просмотров: 4788
Последний ответ 04.01.2020, 16:45:27
от xpank
Не отображаются пункты в меню

Автор physic

Ответов: 20
Просмотров: 22998
Последний ответ 20.09.2019, 16:54:01
от beliyadm
Как в ARI Ext Menu добиться работы параметра "Показать в меню"?

Автор vasmed

Ответов: 1
Просмотров: 3537
Последний ответ 01.03.2019, 11:12:18
от vasmed