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

Kostelano

  • Давно я тут
  • 525
  • 52 / 1
 *DRINK*

Добрый вечер! Необходимо сделать так, чтобы при нажатии на пункт меню появлялось модальное окно с какой-нить другой информацией.

Как реализовать подобное?
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Пункт меню - модальным окном. Как?
« Ответ #1 : 02.12.2014, 01:08:14 »
прикрутить любой Lightbox (или использовать стандартный), для ссылки в меню назначить нужный класс (к примеру modal или lightbox, смотря какой скрипт JS используется)
Ссылку сделать типом на материал, в материал вставить все что угодно
Можно еще добавить в URL другой тип шаблона или вообще ссылаться на другой component уровня шаблона
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

aspidy

  • Завсегдатай
  • 1008
  • 55 / 1
  • Миграция joomla 1.0-1.5-2.5
Re: Пункт меню - модальным окном. Как?
« Ответ #2 : 02.12.2014, 05:57:46 »
Для стандартной Joomla класс modal пример можете посмотреть здесь http://demo.clubby.kz/
Мелкий ремонт. skype poisk-plus
*

dasisgood

  • Осваиваюсь на форуме
  • 25
  • 1 / 0
Re: Пункт меню - модальным окном. Как?
« Ответ #3 : 02.12.2014, 12:20:42 »
http://ruseller.com/lessons.php?id=1415&rub=2 - это всплывающее окно на css3.

Пихаете HTML куда-нить перед закрывающимся </body>, заключаете его в нужный контейнер (как в примере выше).
Теперь он появится только при нажатии на ссылку с определенным ID.
Создаём пункт меню, тип - внешний URL, вставляем ту самую ссылку с определенным ID.

Сам не испытывал, но, думаю, проканает...
*

aspidy

  • Завсегдатай
  • 1008
  • 55 / 1
  • Миграция joomla 1.0-1.5-2.5
Re: Пункт меню - модальным окном. Как?
« Ответ #4 : 02.12.2014, 12:26:22 »
В принципе любой Lightbox проканает....
Мелкий ремонт. skype poisk-plus
*

Kostelano

  • Давно я тут
  • 525
  • 52 / 1
Re: Пункт меню - модальным окном. Как?
« Ответ #5 : 03.12.2014, 01:20:23 »
Ребята, спасибо всем, особенно dasisgood - разобрался по его ссылке ^-^.

Для наглядности, разложу по полочкам что получилось и как делать - для тех, кто впервые столкнется с этим вопросом.

===============================================================================================

1. В теги <body> нашего шаблона вставляем html-текст:

Код
<!-- Форма для модального окна -->
<a href="#x" class="overlay" id="cities"></a>
<div class="popup">
<h2>Заглавный текст</h2>
<p>Слой содержит перекрывающий слой в элементе div и некоторое содержание с кнопкой для закрытия окна.<br /><br /><a href="1.html" target="_blank">Ссылка 1</a> | <a href="2.html" target="_blank">Ссылка 2</a> | <a href="3.html" target="_blank">Ссылка 3</a></p>
<a class="close-popup" href="#close"></a>
</div>

Отметим для себя, что ID нашей формы id="cities" (вторая строка).

Не забываем сохранить файл в кодировке UTF-8.

2. Добавляем стилизацию модального окна в CSS-файл шаблона, мой вариант:

Код
.overlay {
background-color: rgba(0, 0, 0, 0.6);
bottom: 0;
cursor: default;
left: 0;
opacity: 0;
position: fixed;
right: 0;
top: 0;
visibility: hidden;
z-index: 1;

-webkit-transition: opacity .5s;
-moz-transition: opacity .5s;
-ms-transition: opacity .5s;
-o-transition: opacity .5s;
transition: opacity .5s;
}
.overlay:target {
visibility: visible;
opacity: 1;
}
.popup {
background-color: #fff;
display: inline-block;
left: 50%;
opacity: 0;
padding: 20px;
position: fixed;
text-align: justify;
top: 40%;
visibility: hidden;
z-index: 10;

-webkit-transform: translate(-50%, -50%);
-moz-transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
-o-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);

-webkit-border-radius: 6px;
-moz-border-radius: 6px;
-ms-border-radius: 6px;
-o-border-radius: 6px;
border-radius: 6px;

-webkit-transition: opacity .5s, top .5s;
-moz-transition: opacity .5s, top .5s;
-ms-transition: opacity .5s, top .5s;
-o-transition: opacity .5s, top .5s;
transition: opacity .5s, top .5s;
}
.overlay:target+.popup {
top: 50%;
opacity: 1;
visibility: visible;
}
.close-popup {
background: transparent;
line-height: 20px;
position: absolute;
right: 0;
top: 0;
margin: 10px 12px;
text-align: center;
text-decoration: none;
}
.close-popup:before {
color: #cccccc;
display: block;
content: "\f00d";
font-family: FontAwesome;
}
.close-popup:hover { text-decoration: none; }
.popup p, .popup div { margin-bottom: 10px; }

3. Создаем пункт меню, тип: Системные ссылки > Внешний URL и в качестве внешней ссылки прописываем наш ID (см. пункт 1), а именно #cities в данном случае.

Полученный результат: при нажатии на пункт меню всплывает модальное окно.

« Последнее редактирование: 03.12.2014, 01:25:18 от Kostelano »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Ошибка при создании пункта меню

Автор IvKir

Ответов: 26
Просмотров: 24686
Последний ответ 09.12.2020, 10:57:49
от 78Кристина87
[Решено] Как убрать ссылку с активного пункта меню в Joomla 3.2?

Автор Vas80

Ответов: 5
Просмотров: 25158
Последний ответ 23.04.2014, 13:06:21
от Vas80
[Решено] Ссылка выход в меню

Автор Негодяй

Ответов: 17
Просмотров: 19195
Последний ответ 02.04.2014, 23:21:38
от Негодяй
[Решено] Из меню ссылка на якорь в материале

Автор AlekVolsk

Ответов: 4
Просмотров: 15087
Последний ответ 21.03.2014, 08:34:34
от AlekVolsk
[Решено] Как сделать название меню в две строки?

Автор alexeyhead

Ответов: 10
Просмотров: 16327
Последний ответ 10.03.2014, 20:43:49
от alexeyhead