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

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Псевдокласс first-letter в IE6
« : 25.02.2008, 15:10:57 »
Знатоки CSS, поделитесь умением :)
Хочу сделать буквицу для ссылок в главном меню, в стилях имею:
a.mainlevel:first-letter{color: #FFBF00;} - работает в мозилле как надо, в IE не отображает псевдокласс
Стоит поставить пробел перед открывающей скобкой
a.mainlevel:first-letter {color: #FFBF00;} - в осле слетает оформление меню вообще
Доктайп объявлен
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
Грешу на него...
Вот такой пример корректно работает везде, а вот a.mainlevel не хочет...
Код
<style>
h1:first-letter {text-decoration:underline;}
</style>
<h1>hello</h1>
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

poizon

  • Захожу иногда
  • 495
  • 187 / 1
  • Buu
Re: Псевдокласс first-letter в IE6
« Ответ #1 : 25.02.2008, 15:34:13 »
вот что найти смог

хотя уверен, что читал уже ))
« Последнее редактирование: 25.02.2008, 15:40:52 от poizon »
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Псевдокласс first-letter в IE6
« Ответ #2 : 25.02.2008, 15:44:06 »
Читал :(
a:link:hover:first-letter {font-weight: bold;} - отрабатывает ховер только в IE, в мозилле вообще не работает (причем вся ссылка выделяется)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Псевдокласс first-letter в IE6
« Ответ #3 : 25.02.2008, 15:58:35 »
В общем сейчас имею такие стили:
Код
a.mainlevel:first-letter{color: #FFBF00; font-size: 20px; }
a.mainlevel:hover:first-letter{color: #ffffff; font-size: 20px; }
a.mainlevel:link, a.mainlevel:visited {
background-image: url(../images/menu_bg.gif);
display:block;
float:left;
background-repeat: no-repeat;
width: 121px;
height: 47px;
color: #ffffff;
text-align: center;
padding-top: 20px;
font-size: 16px;
text-transform: uppercase;
text-decoration: none;
font-weight: bold;
font-family: Helvetica, Geneva, Verdana,  Arial,  sans-serif;
}
a.mainlevel:hover {
background-position: 0 -67px;
color: #FFBF00;
}
a.mainlevel#active_menu {
background-position: 0 -67px;
}
Именно без пробелов - в мозилле работает. С пробелами слетает в дефолтное отображение в IE, пока никакие манипуляции не помогли :)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Псевдокласс first-letter в IE6
« Ответ #4 : 29.02.2008, 03:14:29 »
да все уже сказал - делаем меню, стандартное, горизонтального расположения
Код
<table width="100%" border="0" cellpadding="0" cellspacing="1">
<tr>
<td nowrap="nowrap">
<a href="" class="mainlevel" id="active_menu">ссылка активная</a>
<a href="" class="mainlevel" >вторая ссылка</a>
</td>
</tr>
</table>
В стилях имею выше приведенный в 3-м посте стили.
Без пробелов в мозилле работает как само по себе так и при наведении, в ИЕ не работает ни link ни hover - стоит поставить пробел перед скобкой  - в ИЕ вообще стили не хватаются для меню.
В вложении - первая картика без пробелов: сверху отображение кнопки для мозиллы link слева и hover справа (то есть все как и планировалось), снизу в IE 6 - псевдоклассы не работают
Вторая картинки - пробел перед скобкой - в мозилле все также работает, а IE 6 слетают вообще стили
            

[вложение удалено Администратором]
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Псевдокласс first-letter в IE6
« Ответ #5 : 01.03.2008, 16:43:42 »
OnTheFlyRU - если честно, первый раз вижу от вас подобную активность )
Данный пример не помог, ибо проблема в разной интерпретации мозиллы и 6-го ИЕ строки:
.mainlevel:first-letter {color: #FFBF00; font-size: 20px; }
А точнее - наличие\отсутствие пробела перед скобкой.
В общем пока отказался вообще от данной идеи, всем спасибо ))
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Псевдокласс first-letter в IE6
« Ответ #6 : 01.03.2008, 17:03:16 »
Код
<table width="100%" border="0" cellpadding="0" cellspacing="1">
<tr>
<td nowrap="nowrap">
<a href="" class="mainlevel" id="active_menu">ссылка активная</a>
<a href="" class="mainlevel" >вторая ссылка</a>
</td>
</tr>
</table>
Вот так выглядит исходный код.
В стилях:
Код
a.mainlevel:first-letter{color: #FFBF00; font-size: 20px; }
a.mainlevel:hover:first-letter{color: #ffffff; font-size: 20px; }
a.mainlevel:link, a.mainlevel:visited {
background-image: url(../images/menu_bg.gif);
display:block;
float:left;
background-repeat: no-repeat;
width: 121px;
height: 47px;
color: #ffffff;
text-align: center;
padding-top: 20px;
font-size: 16px;
text-transform: uppercase;
text-decoration: none;
font-weight: bold;
font-family: Helvetica, Geneva, Verdana,  Arial,  sans-serif;
}
a.mainlevel:hover {
background-position: 0 -67px;
color: #FFBF00;
}
a.mainlevel#active_menu {
background-position: 0 -67px;
}
На отрицательный background не обращать внимание - это у меня картинка\подложка сдвигается вверх.
В вложении 4-го поста две картинки:
Первая картинка без пробелов (a.mainlevel:first-letter{}): сверху отображение кнопки для мозиллы link слева и hover справа (то есть все как и планировалось), снизу в IE 6 - псевдоклассы не работают, но хотя бы стили для a.mainlevel:link, a.mainlevel:visited не слетают.
Вторая картинка - пробел перед скобкой (a.mainlevel:first-letter {}) - в мозилле все также работает, а IE 6 слетают вообще стили.

Вообще идея какая - для обычной и посещенной ссылки выделить первый символ цветом и размером (желтый и 20пкс), для события hover - цвет первого символа вернуть в белый, а остальные покрасить желтым.
В верхней половине первой картинки видно как оно должно было быть - ссылка обычная слева, ссылка наведенная справа.

Проблема в том наличии\отсутствии пробела перед скобкой - стоит поставить его - в ИЕ все исчезает.
Эксперементировал с различными DOCTYPE , но решения пока не нашел)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Псевдокласс first-letter в IE6
« Ответ #7 : 01.03.2008, 17:23:21 »
Извиняюсь, видимо я что-то тоже путаю...
В чистом виде у меня это тоже работает, а вот в связке в движком нет.
Видимо где то стили накладываются.
Спасибо за помощь, пойду чистить классы, позже отпишу
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Свойство letter-spacing по-разному отображается на разных мониторах

Автор V@lentin

Ответов: 1
Просмотров: 1302
Последний ответ 19.07.2018, 20:53:29
от Zelyonkin
Не применяется псевдокласс :not

Автор intedant

Ответов: 7
Просмотров: 959
Последний ответ 29.12.2015, 14:25:33
от intedant